ホームページ >WeChat アプレット >ミニプログラム開発 >ミニプログラム: wx:key を使用して、wx:for のレンダリング効率を向上させます。

ミニプログラム: wx:key を使用して、wx:for のレンダリング効率を向上させます。

若昕
若昕転載
2019-04-01 14:41:193842ブラウズ


この記事の内容は主に、wx:for## のレンダリング効率を向上させるための小さなプログラムでの wx:key の使用について説明します。


#wx:key を追加すると wx:for のレンダリング効率が向上する理由は (私の暫定的な理解です)

    setData の後に wx:key を追加しないでください。配列内のデータが変更されると、フロントエンド レンダリング オブジェクト
  • と wx:key が再レンダリングされます。レンダリング、対応するオブジェクトの並べ替え。変更されていないオブジェクトは再作成されません
公式の説明を参照してください

データの変更によりレンダリング レイヤが再レンダリングされると、キーを持つコンポーネントがレンダリングされます。が修正されると、フレームワークは、コンポーネントが独自の状態を維持し、リストのレンダリングの効率を向上させるために、コンポーネントが再作成されるのではなく順序が変更されることを保証します。

検証が必要な質問

wx: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: ミニプログラム: wx:key を使用して、wx:for のレンダリング効率を向上させます。, name: &#39;php&#39;},
    {id: 4, name: &#39;javascript&#39;},
    {id: 3, name: &#39;golang&#39;},
    {id: 2, name: &#39;python&#39;},
    {id: 5, name: &#39;java&#39;},
  ],
},

ミニプログラム: wx:key を使用して、wx:for のレンダリング効率を向上させます。

テスト結果から、並べ替えには影響しません。

キーが同じ名前である場合にエラーが報告されるかどうか

data: {
  languages: [
    {id: ミニプログラム: wx:key を使用して、wx:for のレンダリング効率を向上させます。, name: &#39;php&#39;},
    {id: 4, name: &#39;javascript&#39;},
    {id: 3, name: &#39;golang&#39;},
    {id: 2, name: &#39;python&#39;},
    {id: 5, name: &#39;java&#39;},
  ],
},

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

	this.setData({
		languages: languages
	})
}

WeChat アプレット開発ツールは警告のみを報告し、プログラムがクラッシュすることはありません

VM6265:2 wx:key に同じキー {5} を設定しないでください

奇妙なのは、この警告が再レンダリング時にのみ報告されることです。初期化中は、警告は発生しません。

関連ビデオ リンク:

ミニ プログラム開発チュートリアル

以上がミニプログラム: wx:key を使用して、wx:for のレンダリング効率を向上させます。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はcsdn.netで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。