91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

小程序中如何使用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

綦江县| 平塘县| 利辛县| 晋江市| 沙雅县| 太康县| 广东省| 邹城市| 巧家县| 团风县| 滁州市| 台北县| 通海县| 本溪市| 博白县| 浙江省| 石泉县| 建瓯市| 茶陵县| 宁南县| 库伦旗| 珲春市| 亚东县| 左云县| 北宁市| 广德县| 闸北区| 嘉荫县| 游戏| 康保县| 阳高县| 金湖县| 绥滨县| 荥阳市| 长春市| 敖汉旗| 左贡县| 蚌埠市| 宁海县| 赫章县| 西林县|