亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

微信小程序使用this.setData()遇到的問題及解決方案詳解

 更新時間:2022年08月23日 08:55:26   作者:一只程序龜  
this.setData估計是小程序中最經(jīng)常用到的一個方法,但是要注意其實他是有限制的,忽略這些限制的話,會導致數(shù)據(jù)無法更新,下面這篇文章主要給大家介紹了關于微信小程序使用this.setData()遇到的問題及解決方案,需要的朋友可以參考下

前言

最近在學習小程序時遇到了關于setData()的不少問題,在這里做一些總結和記錄。

使用方法總結

在更改setData下的變量時,直接寫key名就可以了的,不用寫this.data.屬性,如下所示

Page({
    data:{
        value:'hello'
    }
    this.setData({
    value:'修改的值'
    //錯誤寫法:this.data.value:''
    //注意key的名稱一定是data中的名稱
})
})

setData的第二個參數(shù)是一個回調函數(shù),在頁面渲染完后執(zhí)行。

this.setData({
      value:'hello'
    }, () => { //第二個參數(shù)
       console.log("在頁面渲染完value后再執(zhí)行");
    })
?

利用setData()修改數(shù)組對象下的一個屬性

方法一:使用雙引號或單引號

Page({
    data:{   
          List: [{
            id:0,
            name:'test01'
        }]
    }
})
this.setData({
   "List.id": 6
})

方法二:使用中擴號

this.setData({
   ['List.id']: 2
})

如果數(shù)組下有多個對象,我們要如何修改其中的一個屬性呢?

wxml部分代碼:

//wxml
<block wx:for="{{List}}" wx:key="index" id="{{index}}">
<view class="message">
<view>{{item.id}}、</view>
<view>{{item.name}}</view>
</view>
?
<button bindtap="change" id="{{item.id}}">點我修改數(shù)據(jù)中的name</button>
</block>

錯誤寫法:

//index.js
Page({
 data:{
        List:
        [{
            id:0,
            name:'test01'
        },
        {
            id:1,
            name:'test02'
        }],
    },
change(event){
    let index = event.currentTarget.id;
    this.setData({
    List[index].name:'newName'
})
}
})

這樣寫會報錯:

Only digits(0-9) can be put inside [] in the path string

正確寫法:

change(event){
 let index = event.currentTarget.id;
    this.setData({
    [`List[${index}].name`]:'newName'
})
}

簡易雙向綁定

如果需要在用戶輸入時改變this.data.value,需要借助簡易雙向綁定機制

在對應項目前加入model: 前綴即可

使用時控制臺會有警告:Do not have handler in component

原因是沒有綁定對應的事件,在不影響結果的情況下可以無視報錯或者加一個空函數(shù)

或者使用setData()自己觸發(fā)綁定更新

<input type="text"  model:value="{{value1}}" bindinput="valueChange"/> 
<input type="text"  value="{{value2}}" bindinput="inputChange"/> 
data:{
     value1:'',
     value2:''
}
//綁定model:并不出現(xiàn)警告的方法
valueChange(){
     console.log(this.data.value);
 }
//利用setData()更新
inputChange(e){
    let changeValue= e.detail.value;
    this.setData({
    value:changeValue
})
    console.log(this.data.value);
    },

在自定義組件中也能使用雙向綁定

注意點:用于雙向綁定的表達式有如下限制:

1、只能是一個單一字段的綁定,如下都是非法的;

<input model:value="值為 {{value}}" />
<input model:value="{{ a + b }}" />

2、目前,尚不能支持data路徑的表達式,如

<input model:value="{{ a.b }}" />

參考了一些帖子和官方文檔,如有錯誤或更好的方案,歡迎指出和交流!

總結

到此這篇關于微信小程序使用this.setData()遇到的問題及解決方案的文章就介紹到這了,更多相關小程序使用this.setData()問題解決內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論