首页 > 编程语言 >【Vue】【uni-app】【小程序】多层嵌套方法导致this指向出错:解析 JSON 失败: TypeError: Cannot read property ‘push‘ of undefined

【Vue】【uni-app】【小程序】多层嵌套方法导致this指向出错:解析 JSON 失败: TypeError: Cannot read property ‘push‘ of undefined

时间:2024-09-24 15:22:19浏览次数:17  
标签:Vue console title read res JSON const property wx

项目场景:

在使用vue+uni-app开发微信小程序的时候,调试报错:解析 JSON 失败: TypeError: Cannot read property ‘push’ of undefined
在这里插入图片描述


问题描述

报错如下:

以下是出问题的代码:

data() {
        return {
            fileLists: [],        
        }
       }
// 上传文件        
        chooseMessageFile() {
            var uid = this.uid
            wx.chooseMessageFile({
                count: 1, // 默认9
                type: 'file',
                // extension: ['.zip', '.docx', '.doc', '.pdf', 'txt', '.csv', '.xlsx', '.ppt', '.pptx'],
                success: function (res) {
                    console.log(res)
                    const tempFilePaths = res.tempFiles[0].path;
                    const tempFileName = res.tempFiles[0].name;

                    wx.uploadFile({
                        url: BASE_API_URL + '/Upload/upload', //接口地址
                        filePath: tempFilePaths,
                        name: 'file',
                        formData: {
                            'uid': uid
                        },
                        success: (res) => {
                            try {
                                const jsonData = JSON.parse(res.data);
                                console.log('解析后的JSON数据:', jsonData);
                                // 处理 JSON 数据
                                if (jsonData.code == 0) {
                                    const link = jsonData.data;
                                    console.log('解析后的link:', link);

                                    const linkData = { annex_id: "", title: tempFileName, link: jsonData.data };
                                    console.log('解析后的linkData:', linkData);
                                    console.log('这是fileLists:', that.fileLists);
                                    this.fileLists.push(linkData);
                                    wx.showToast({
                                        title: '上传成功',
                                        icon: 'success'
                                    });
                                } else {
                                    wx.showToast({
                                        title: '上传失败',
                                        icon: 'none'
                                    });
                                }
                            } catch (e) {
                                console.error('解析 JSON 失败:', e);
                                console.error('原始数据:', res.data);
                                wx.showToast({
                                    title: '解析 JSON 失败',
                                    icon: 'none'
                                });
                            }

                        },
                        fail: (err) => {
                            console.error('上传失败:', err);
                            wx.showToast({
                                title: '上传失败',
                                icon: 'none'
                            });
                        }
                    })
                }
            })
        },

原因分析:

提示:这里填写问题的分析:

在代码中多次打印,排查问题,最终问题锁定在了下面这行代码中:

this.fileLists.push(linkData);

请教了一下以前的学长,得知问题可能出现在多层方法嵌套上,导致this的指向错误


解决方案:

在最外层的方法开始的时候增加如下代码:

var that = this

并且将嵌套的方法中的this改成that

// 上传文件        
        chooseMessageFile() {
            var uid = this.uid
            wx.chooseMessageFile({
                count: 1, // 默认9
                type: 'file',
                // extension: ['.zip', '.docx', '.doc', '.pdf', 'txt', '.csv', '.xlsx', '.ppt', '.pptx'],
                success: function (res) {
                    console.log(res)
                    const tempFilePaths = res.tempFiles[0].path;
                    const tempFileName = res.tempFiles[0].name;
                    wx.uploadFile({
                        url: BASE_API_URL + '/Upload/upload', //接口地址
                        filePath: tempFilePaths,
                        name: 'file',
                        formData: {
                            'uid': uid
                        },
                        success: (res) => {
                            try {
                                const jsonData = JSON.parse(res.data);
                                //console.log('解析后的JSON数据:', jsonData);
                                // 处理 JSON 数据
                                if (jsonData.code == 0) {
                                    const link = jsonData.data;
                                    //console.log('解析后的link:', link);
                                    const linkData = { annex_id: "", title: tempFileName, link: jsonData.data };
                                    //console.log('解析后的linkData:', linkData);
                                    //console.log('这是fileLists:', that.fileLists);
                                    that.fileLists.push(linkData);
                                    wx.showToast({
                                        title: '上传成功',
                                        icon: 'success'
                                    });
                                } else {
                                    wx.showToast({
                                        title: '上传失败',
                                        icon: 'none'
                                    });
                                }
                            } catch (e) {
                                console.error('解析 JSON 失败:', e);
                                console.error('原始数据:', res.data);
                                wx.showToast({
                                    title: '解析 JSON 失败',
                                    icon: 'none'
                                });
                            }
                        },
                        fail: (err) => {
                            console.error('上传失败:', err);
                            wx.showToast({
                                title: '上传失败',
                                icon: 'none'
                            });
                        }
                    })
                }
            })
        },

问题解决

在这里插入图片描述

标签:Vue,console,title,read,res,JSON,const,property,wx
From: https://blog.csdn.net/SSRHR/article/details/142490264

相关文章

  • 《深入解析 Java 中的 ThreadLocal》
    ThreadLocal1.概述ThreadLocal被称为线程局部变量,用于在线程中保存数据。由于在ThreadLocal中保存的数据仅属于当前线程,所以该变量对其他线程而言是隔离的,也就是说该变量是当前线程独有的变量。ThreadLocal用于在同一个线程间,在不同的类和方法之间共享数据的的场景,也可以......
  • Arthas thread(查看当前JVM的线程堆栈信息)
    文章目录二、命令列表2.1jvm相关命令2.1.2thread(查看当前JVM的线程堆栈信息)举例1:展示[数字]线程的运行堆栈,命令:thread线程ID举例2:找出当前阻塞其他线程的线程二、命令列表2.1jvm相关命令2.1.2thread(查看当前JVM的线程堆栈信息)使用场景:在Arthas中,thread命令用于查看和分......
  • 基于nodejs+vue校园二手市场平台[开题+源码+程序+论文]计算机毕业设计
    本系统(程序+源码+数据库+调试部署+开发环境)带文档lw万字以上,文末可获取源码系统程序文件列表开题报告内容研究背景随着高等教育的普及和校园生活的丰富多彩,学生们在日常学习与生活中积累了大量不再需要的二手物品,如书籍、学习资料、电子产品、生活用品等。同时,新入学的学......
  • 基于nodejs+vue校园二手商品交易平台[开题+源码+程序+论文]计算机毕业设计
    本系统(程序+源码+数据库+调试部署+开发环境)带文档lw万字以上,文末可获取源码系统程序文件列表开题报告内容研究背景随着高等教育的普及和校园生活的丰富多彩,大学生群体对各类商品的需求日益增长,同时也伴随着大量物品的闲置与浪费。特别是在每学期末或毕业生离校之际,大量书......
  • 基于nodejs+vue校园二手商城[开题+源码+程序+论文]计算机毕业设计
    本系统(程序+源码+数据库+调试部署+开发环境)带文档lw万字以上,文末可获取源码系统程序文件列表开题报告内容研究背景在数字化高速发展的今天,校园生活日益丰富多彩,学生间的物品流转需求也日益增长。传统的二手交易方式,如校园公告板、微信群等,虽在一定程度上满足了部分需求,但......