日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

微信小程序中this指向作用域问题this.setData is not a function报错

發布時間:2023/12/31 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 微信小程序中this指向作用域问题this.setData is not a function报错 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在微信小程序中我們一般通過以下方式來修改data中的數據

this.setData({index1: e.detail.value})

比如在函數里面修改數據

bindFaChange1: function (e) {this.setData({index1: e.detail.value})}

但是當我們通過wx.request請求網絡數據成功后綁定數據時候報以下錯誤

this.setData is not a function

代碼如下:

doCalc:function(){wx.request({url: url,method:'POST',header: {'content-type': 'application/json' // 默認值},success: function (res) {if (res.data.code == 0){this.setData({maxCount: res.data.maxCount});}}})}

這是因為this作用域指向問題 ,success函數實際是一個閉包 , 無法直接通過this來setData

那么需要怎么修改呢?

我們通過將當前對象賦給一個新的對象

var _this = this;

然后使用_this 來setData就行了

完整代碼

doCalc:function(){var _this = this;wx.request({url: url,method:'POST',header: {'content-type': 'application/json' // 默認值},success: function (res) {if (res.data.code == 0){_this.setData({maxCount: res.data.maxCount});}}})}

另外說一下 , 在es6中 , 使用箭頭函數是不存在這個問題的

例如 :

setTimeout( () => {console.log(this.type + ' says ' + say)}, 1000)

當我們使用箭頭函數時,函數體內的this對象,就是定義時所在的對象,而不是使用時所在的對象。
并不是因為箭頭函數內部有綁定this的機制,實際原因是箭頭函數根本沒有自己的this,它的this是繼承外面的,因此內部的this就是外層代碼塊的this。

總結

以上是生活随笔為你收集整理的微信小程序中this指向作用域问题this.setData is not a function报错的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。