微信小程序开发踩坑:TypeError: Cannot read property 'setData' of undefinedk OR this.setData is not a function

微信小程序开发过程中,需要使用this.setData来设置变量,偶尔会出现TypeError: Cannot read property ‘setData’ of undefinedk OR this.setData is not a function的报错。

其实这样的异常经常在调用各种API的回调函数(success:function(res) fail:function(res) complete:function(res))当中,使用this相关方法和属性中出现的。

拿一段带bug的上传图片至数据库的云开发代码来讲解。

  upImages:function(){    
   	wx.chooseImage({      
   		success: function(res){ 
   			wx.cloud.uploadFile( 
   				cloudPath: `${ Math.floor(Math.random() * 10000) }.png`,  
   				filePath: res.tempFilePaths[0]}) 
   			.then(res=>{this.setData({imageFiles:res.fileID})})  
   			.catch(err=>{console.log(err)}); 
   			wx.showToast({ title: '上传成功', }) }, }) },

调用了wx.chooseImage选择图片的api,在success回调函数中直接this.setData就会报错了,原因是此时this变量的指向作用域不再是Pages对象了(js中的Pages数组)仅限于success函数中针对this作用域的问题有两种解决办法

  1. 将回调函数,写成监听函数,监听Pages事件。
     success:res=>{ ,,,,,,,}
  1. 增加一个变量来保存this的作用域
var that = this
success: function(res){
,,,,
.then(res=>{that.setData({imageFiles:res.fileID})
,,,,
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,"TypeError: Cannot read property 'context' of undefined"是微信小程序报错的一种情况。该错误通常发生在尝试访问未定义(undefined)对象的属性时。出现这个错误的原因可能是在代码中尝试访问一个不存在或未定义的对象的属性。 解决这个问题的方法可以包括以下步骤: 1. 首先,检查代码中出现错误的地方,找到引发错误的行数和具体位置。 2. 确认是否在访问属性之前正确地定义了对象。可以使用console.log()或其他调试方法来查看对象的值和属性。 3. 确保对象存在并且已经正确初始化。如果对象为空或未定义,可能需要检查代码逻辑并确保正确初始化该对象。 4. 如果是异步操作,确保在获取到需要的数据后再进行属性访问操作。可能需要使用回调函数、Promise或async/await等方式来处理异步操作。 5. 使用条件语句或try-catch语句来捕获可能导致错误的情况,以避免程序崩溃。 6. 如果以上方法都无法解决问题,可以参考微信官方文档或开发者社区中的相关讨论,寻求更具体的解决方案。 需要注意的是,具体解决方法可能因为代码的不同而有所差异,因此建议根据自己的代码情况来选择合适的方法来解决该错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [微信小程序 报错:TypeError: Cannot read propertysetData‘ of undefined 及两种解决方法](https://blog.csdn.net/qq_43263320/article/details/113706520)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [微信小程序报错: thirdScriptError的错误问题](https://download.csdn.net/download/weixin_38499349/13129051)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值