Maison >Applet WeChat >Développement de mini-programmes >Introduction détaillée de l'applet WeChat wx:key
Mini programme WeChat wx:key Quand j'étudiais, je ne comprenais pas très bien ce qui se passait. Après avoir vérifié les informations en ligne, j'ai fait le tri :
Personnellement, j'ai l'impression que les exemples officiels. ne sont pas très clairs. L'explication officielle est la suivante :
wx:key
Si la position des éléments dans la liste change dynamiquement ou si de nouveaux éléments sont ajoutés. la liste et que vous souhaitez que les éléments de la liste restent leurs propres caractéristiques et états (comme le contenu d'entrée dans 0f0306f9b187f2e363126bc29c8b1420, l'état sélectionné de 698d939a2c9041f2302734cfeb04788e), vous devez utiliser wx : clé pour spécifier l’identifiant unique de l’élément dans la liste.
La valeur de wx:key est fournie sous deux formes
chaîne, représentant une certaine propriété de l'élément dans le tableau de la boucle for, la valeur du la propriété doit être la seule chaîne ou numéro de la liste et ne peut pas être modifiée dynamiquement.
Le mot-clé réservé *this représente l'élément lui-même dans la boucle for. Cette représentation nécessite que l'élément lui-même soit une chaîne ou un nombre unique, tel que :
Déclenché lorsque les données. changements Lorsque la couche de rendu effectue un nouveau rendu, les composants avec des clés seront corrigés et le framework veillera à ce qu'ils soient réorganisés plutôt que recréés pour garantir que les composants conservent leur propre état et améliorent les performances de rendu de la liste. .
Si wx:key n'est pas fourni, un avertissement sera signalé. Si vous savez clairement que la liste est statique ou que vous n'avez pas besoin de prêter attention à son ordre, vous pouvez choisir de l'ignorer.
Exemple de code :
<switch wx:for="{{objectArray}}" wx:key="unique" style="display: block;"> {{item.id}} </switch> <button bindtap="switch"> Switch </button> <button bindtap="addToFront"> Add to the front </button> <switch wx:for="{{numberArray}}" wx:key="*this" style="display: block;"> {{item}} </switch> <button bindtap="addNumberToFront"> Add to the front </button> Page({ data: { objectArray: [ {id: 5, unique: 'unique_5'}, {id: 4, unique: 'unique_4'}, {id: 3, unique: 'unique_3'}, {id: 2, unique: 'unique_2'}, {id: 1, unique: 'unique_1'}, {id: 0, unique: 'unique_0'}, ], numberArray: [1, 2, 3, 4] }, switch: function(e) { const length = this.data.objectArray.length for (let i = 0; i < length; ++i) { const x = Math.floor(Math.random() * length) const y = Math.floor(Math.random() * length) const temp = this.data.objectArray[x] this.data.objectArray[x] = this.data.objectArray[y] this.data.objectArray[y] = temp } this.setData({ objectArray: this.data.objectArray }) }, addToFront: function(e) { const length = this.data.objectArray.length this.data.objectArray = [{id: length, unique: 'unique_' + length}].concat(this.data.objectArray) this.setData({ objectArray: this.data.objectArray }) }, addNumberToFront: function(e){ this.data.numberArray = [ this.data.numberArray.length + 1 ].concat(this.data.numberArray) this.setData({ numberArray: this.data.numberArray }) } })
Merci d'avoir lu, j'espère que cela pourra aider tout le monde, merci pour votre soutien site!
Pour plus d'introduction détaillée de l'applet WeChat wx:key et des articles connexes, veuillez faire attention au site Web PHP chinois !