微信小程序报错:this.setData is not a function的解决办法

网友投稿 709 2023-03-29


微信小程序报错:this.setData is not a function的解决办法

微信小程序 报错:this.setData is not a function

在page中定义的代码如下,代码会报错:this.setData is not a function

pasteEncryptedText:function(){

let decryptedPass = this.data.decryptedPassword;

if (decryptedPass == '' ){

wx.showToast({

title: '请先输入解密密码',

mask: true,

success: function (res) {

setTimeout(function () {

wx.hideToast();

}, 4000);

},

});

return;

}else{

wx.getClipboardData({

success: function (res) {

if ( res.data == '' ){

wx.showToast({

title: '剪贴板没有内容',

mask: true,

success: function (res) {

setTimeout(function () {

wx.hideToast();

}, 4000);

},

})

}else{

console.log(decryptedPass);

console.log(res.data);

this.setData({

encryptedTextDecode: res.data,

originalTextDecode: desEncryptedDecrypted.decrypt(res.data, decryptedPass),

});

console.log(this.data.originalTextDecode);

}

}

});

}

}

问题分析:在函数 pasteEncryptedText()里面嵌套调用另一个函数 wx.showToast(),而setData()是在wx.showToast()中调用的,此时this.setData()

中的this不是page,而是wx.showToast()这个对象了

解决方法:

在函数pasteEncryptedText()一开始处将this对象保存:let that = this;

pasteEncryptehttp://dText:function(){

let dechttp://ryptedPass = thihttp://s.data.decryptedPassword;

let that = this;

if (decryptedPass == '' ){

wx.showToast({

title: '请先输入解密密码',

mask: true,

success: function (res) {

setTimeout(function () {

wx.hideToast();

}, 4000);

},

});

return;

}else{

wx.getClipboardData({

success: function (res) {

if ( res.data == '' ){

wx.showToast({

title: '剪贴板没有内容',

mask: true,

success: function (res) {

setTimeout(function () {

wx.hideToast();

}, 4000);

},

})

}else{

console.log(decryptedPass);

console.log(res.data);

that.setData&http://lt;/strong>({

encryptedTextDecode: res.data,

originalTextDecode: desEncryptedDecrypted.decrypt(res.data, decryptedPass),

});

console.log(that.data.originalTextDecode);

}

}

});

}

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望通过本文能帮助到大家,谢谢大家对本站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:如何编写接口的测试用例(如何编写接口的测试用例模板)
下一篇:EasyUI Tree树组件无限循环的解决方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~