亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

小程序中如何使用wx:key提升wx:for的渲染效率

發布時間:2021-01-26 12:41:47 來源:億速云 閱讀:203 作者:小新 欄目:移動開發

小編給大家分享一下小程序中如何使用wx:key提升wx:for的渲染效率,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

小程序中使用 wx:key 提升 wx:for 的渲染效率

之所以加上 wx:key 會提升 wx:for 的渲染效率,原因是(我的初步理解)

  • 如果不加 wx:key, 在 setData 之后,如果 array 內的數據如果發生改變,會重新創建前端的渲染對象


  • 加上 wx:key,重新渲染時,只是將對應的對象重新排序。未發生變化的對象,不會重新創建

參考官方的解釋

當數據改變觸發渲染層重新渲染的時候,會校正帶有 key 的組件,框架會確保他們被重新排序,而不是重新創建,以確保使組件保持自身的狀態,并且提高列表渲染時的效率。

需要驗證的問題

加上 wx:key 之后,會根據給定的 key 進行排序么?

寫個簡單的測試頁面

<block wx:for="{{languages}}" wx:for-item="language" wx:key="id">
  <text class="log-item">{{ language.id }} . {{ language.name }}</text>
</block>

data: {
  languages: [
    {id: 1, name: 'php'},
    {id: 4, name: 'javascript'},
    {id: 3, name: 'golang'},
    {id: 2, name: 'python'},
    {id: 5, name: 'java'},
  ],
},

小程序中如何使用wx:key提升wx:for的渲染效率

從測試結果來看,并不會影響到排序。

key 重名時是否會報錯

data: {
  languages: [
    {id: 1, name: 'php'},
    {id: 4, name: 'javascript'},
    {id: 3, name: 'golang'},
    {id: 2, name: 'python'},
    {id: 5, name: 'java'},
  ],
},

click: function () {
	let language = {id: 5, name: 'kotlin'}
	let languages = this.data.languages
	languages.push(language)

	this.setData({
		languages: languages
	})
}

微信小程序開發工具只會報一個警告,并不會導致程序崩潰

VM6265:2 Do not set same key {5} in wx:key

比較奇怪的是,這個警告只有在重新渲染時才會報,如果初始化時就使用同樣的 key,并不會導致警告。

以上是“小程序中如何使用wx:key提升wx:for的渲染效率”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安塞县| 崇州市| 抚顺县| 长寿区| 博乐市| 都安| 焉耆| 晋州市| 横山县| 南木林县| 曲麻莱县| 佛坪县| 宜城市| 桑日县| 双牌县| 正阳县| 文成县| 高清| 新化县| 循化| 舒兰市| 罗江县| 怀安县| 广宁县| 梨树县| 休宁县| 汤阴县| 元阳县| 萨嘎县| 怀来县| 安平县| 竹山县| 丰城市| 蒙山县| 天门市| 公安县| 南通市| 太仓市| 江孜县| 鹿邑县| 岳西县|