Maison >interface Web >Questions et réponses frontales >les propriétés de l'objet vue3 changent

les propriétés de l'objet vue3 changent

WBOY
WBOYoriginal
2023-05-25 11:19:371885parcourir

Avec la sortie officielle de Vue3, les développeurs ont hâte de tester les nouvelles fonctionnalités et améliorations apportées par la nouvelle version. L'un des changements les plus notables est la modification des propriétés des objets. Dans Vue2, si nous voulons surveiller les modifications des propriétés des objets, nous devons utiliser l'observation approfondie ou utiliser $watch pour surveiller manuellement les modifications des propriétés. Cependant, dans Vue3, ce problème a été résolu.

Vue3 fournit un mécanisme automatique de surveillance et de réponse aux modifications des propriétés des objets à l'aide d'objets proxy. Cela signifie que nous pouvons utiliser des objets dans Vue3 comme des objets JavaScript normaux et déclencher automatiquement des mises à jour de la vue.

Jetons un coup d'œil aux détails spécifiques de la mise en œuvre.

Tout d'abord, supposons que nous ayons un composant Vue3 qui contient un objet d'état à l'intérieur et que nous souhaitions écouter les modifications dans les propriétés de l'objet. Nous pouvons définir cet objet et l'attribuer à l'état du composant :

<template>
  <div>
    <p>属性A: {{ obj.A }}</p>
    <p>属性B: {{ obj.B }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      obj: {
        A: '初始值A',
        B: '初始值B'
      }
    }
  }
}
</script>

Dans Vue2, si nous voulons surveiller les modifications dans les propriétés de l'objet, nous devons utiliser $watch ou $watchEffect pour surveiller manuellement les modifications dans chaque propriété. Par exemple :

this.$watch('obj.A', (newValue, oldValue) => {
  console.log(`属性A发生了变化:${oldValue} => ${newValue}`)
})

Dans Vue3, nous pouvons utiliser l'objet Proxy pour écouter toutes les modifications de propriétés de l'objet cible sans écrire $watch ou $watchEffect :

<script>
export default {
  data() {
    return {
      obj: {
        A: '初始值A',
        B: '初始值B'
      }
    }
  },
  created() {
    this.obj = new Proxy(this.obj, {
      set(target, key, value, receiver) {
        // 触发视图更新
        return Reflect.set(target, key, value, receiver)
      }
    })
  }
}
</script>

Nous enveloppons l'objet d'état dans un objet Proxy lorsque le composant est créé . Lorsque l'on modifie les propriétés de l'objet, l'objet Proxy déclenche automatiquement une mise à jour de la vue.

La fonction set de l'objet Proxy sera automatiquement appelée lorsque les propriétés de l'objet sont modifiées. À ce stade, nous pouvons ajouter notre propre logique dans la fonction set, comme imprimer les modifications de propriété ou notifier d'autres composants. Cependant, vous devez vous assurer que l'instruction Reflect.set(target, key, value, Receiver) est renvoyée à la fin, afin que le flux de contrôle revienne au mécanisme de mise à jour de Vue et que la vue soit mise à jour correctement.

L'exemple ci-dessus n'est qu'une simple démonstration. L'objet Proxy de Vue3 implémente plus de fonctionnalités et d'options pour une surveillance plus flexible des propriétés d'objet, y compris des getters et setters personnalisés, la vérification des autorisations de propriété, etc. Les développeurs intéressés peuvent se référer à la documentation officielle de Vue3 pour une étude approfondie.

En bref, l'objet Proxy de Vue3 nous permet d'exploiter les objets à l'intérieur des composants plus naturellement, tout en réduisant la quantité de code fastidieux pour surveiller manuellement les modifications de propriétés. Cela apporte une expérience plus efficace et plus pratique à notre développement.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn