1. 程式人生 > >微信小程序 - wx:key

微信小程序 - wx:key

prope 新的 png developer his 關鍵字 組件 true ram

看官方源碼以及代碼示例:

示例官網:列表渲染wx:key

官方原話

如果列表中項目的位置會動態改變或者有新的項目添加到列表中,並且希望列表中的項目保持自己的特征和狀態(如 <input/> 中的輸入內容,<switch/> 的選中狀態),需要使用 wx:key 來指定列表中項目的唯一的標識符。

wx:key 的值以兩種形式提供

字符串,代表在 for 循環的 array 中 item 的某個 property,該 property 的值需要是列表中唯一的字符串或數字,且不能動態改變。
保留關鍵字 *this 代表在 for 循環中的 item 本身,這種表示需要 item 本身是一個唯一的字符串或者數字,如:
當數據改變觸發渲染層重新渲染的時候,會校正帶有 key 的組件,框架會確保他們被重新排序,而不是重新創建,以確保使組件保持自身的狀態,並且提高列表渲染時的效率。

如不提供 wx:key,會報一個 warning, 如果明確知道該列表是靜態,或者不必關註其順序,可以選擇忽略。

簡而言之就是動態改變的同時,需要保持組件內input的輸入內容以及其它swtich等狀態不會改變.

用一句話來說:*this - 銷毀所有組件狀態且重新創建. unique - 保留所有狀態在原有的基礎上創建 > (GIF演示圖片過小可以拖出保存在桌面或者CTRL+鼠標左鍵可以放大)

技術分享圖片

我們明顯的可以看出*this創建的switch是整齊有序的,而利用unique創建的switch是在原來的基礎上增加上去的.

小程序調試中我們可以調整為*this,總覺得這提示太顯眼了.

技術分享圖片

微信小程序 - wx:key