Maison > interface Web > js tutoriel > le corps du texte

Comment utiliser les propriétés calculées et les écouteurs de méthode de Vue

php中世界最好的语言
Libérer: 2018-06-02 11:30:44
original
1821 Les gens l'ont consulté

Cette fois, je vais vous montrer comment utiliser vue pour calculer les attributs et les auditeurs de méthode. Quelles sont les précautions pour utiliser vue pour calculer les attributs et les auditeurs de méthode. combat Jetons un coup d'œil au cas. Les

Propriétés calculées

Expressions dans les modèles sont très pratiques, mais elles sont conçues pour des opérations simples. Mettre trop de logique dans un modèle peut le rendre trop lourd et difficile à maintenir. Par exemple :

<p id="example">
 {{ message.split('').reverse().join('') }}
</p>
Copier après la connexion

Ici, le modèle n'est plus une simple logique déclarative. Il faut regarder un moment pour se rendre compte qu'ici on veut afficher lachaîne inversée du message variable. Cela devient encore plus difficile à gérer lorsque vous souhaitez référencer la chaîne inversée ici plusieurs fois dans le modèle.

Ainsi, pour toute logique complexe, vous devez utiliser des propriétés calculées.

Exemple de base

<p id="app">
 {{fullName}}
</p>
  
  
var vm = new Vue({
 el: '#app',
 data: {
  firstName: "王",
  lastName: "小智",
  age: 28
 },
 // 计算属性
 computed: {
   fullName: function () {
     console.log("计算了一次")
     return this.firstName + " " + this.lastName
   }
 }
})
Copier après la connexion
Résultat :

Wang Xiaozhi

Ensuite, nous modifions la valeur de l'attribut age via le navigateur, laissez le rendu de la page :

Comme vous pouvez le voir, la méthode que nous avons utilisée pour modifier l'attribut calculé de la valeur d'âge n'a pas été appelée. l'attribut calculé change, comme lastName ou Qu'arrive-t-il au résultat de l'impression lorsque firstName change

Comme vous pouvez le voir, lorsque ses dépendances changent, l'attribut calculé sera recalculé ? .

Cache de propriétés calculées vs méthode

Vous avez peut-être remarqué que nous pouvons obtenir le même effet en appelant une méthode dans une expression :

<p>Reversed message: "{{ fullName() }}"</p>
// 在组件中
methods: {
 fullName: function () {
  console.log("计算了一次")
  return this.firstName + " " + this.lastName;
 }
}
Copier après la connexion
Résultat :

Wang Xiaozhi

De la même manière, en nous référant à ce qui précède, nous modifions la valeur de l'attribut age via le navigateur et laissons la page s'afficher à nouveau :

On peut voir que tant que notre page est restituée, la méthode sera exécutée une fois et la propriété calculée ne sera réévaluée que lorsque ses dépendances associées changeront .

Pourquoi avons-nous besoin de mise en cache ? Supposons que nous ayons une propriété A coûteuse en termes de calcul, qui nécessite de parcourir un vaste tableau et d'effectuer de nombreux calculs. Nous pourrions alors avoir d’autres propriétés calculées qui dépendent de A. Sans mise en cache, nous exécuterions inévitablement le getter de A plusieurs fois ! Si vous ne souhaitez pas de mise en cache, utilisez plutôt des méthodes.

Propriétés calculées vs propriétés d'écoute

Vous avez peut-être remarqué que nous pouvons également obtenir le même effet grâce aux propriétés d'écoute :

var vm = new Vue({
 el: '#app',
 data: {
  firstName: "王",
  lastName: "小智",
  age: 28,
  fullName
 },
 // 计算属性
 watch: {
   firstName: function () {
    console.log("计算了一次");
    this.fullNmae = this.firstName + this.lastName;
   },
   lastName: function () {
    console.log("计算了一次")
    this.fullNmae = this.firstName + this.lastName;
   }
 }
})
Copier après la connexion
Résultat :

Wang Xiaozhi

De la même manière, en référence à ce qui précède, nous modifions la valeur de l'attribut age via le navigateur et laissons la page s'afficher à nouveau :

Comme vous pouvez le constater, pour les modifications qui ne sont pas liées au nom complet, fullName n'a pas changé. Semblable aux propriétés calculées, il y aura un cache qui ne sera réévalué que lorsqu'il sera lié. les dépendances changent, et cela sera comparé aux propriétés calculées. Pour comparer, la version est bien meilleure, n'est-ce pas ?

Lorsque certaines données doivent changer lorsque d'autres données changent, il est facile d'abuser des montres - surtout si vous avez déjà utilisé

AngularJS. Cependant, il est souvent préférable d’utiliser des propriétés calculées plutôt que des rappels de surveillance impératifs.
Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !

Lecture recommandée :

Comment effectuer le contrôle de connexion vue.js

Comment utiliser JS pour obtenir la position absolue des éléments DOM

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal