VueJS - Propriétés calculées
Nous avons déjà vu des méthodes pour l'instance Vue et pour les composants. Les propriétés calculées sont comme des méthodes mais avec quelques différences par rapport aux méthodes, dont nous parlerons dans ce chapitre.
À la fin de ce chapitre, nous serons en mesure de décider quand utiliser les méthodes et quand utiliser les propriétés calculées.
Comprenons les propriétés calculées à l'aide d'un exemple.
Exemple
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "computed_props">
FirstName : <input type = "text" v-model = "firstname" /> <br/><br/>
LastName : <input type = "text" v-model = "lastname"/> <br/><br/>
<h1>My name is {{firstname}} {{lastname}}</h1>
<h1>Using computed method : {{getfullname}}</h1>
</div>
<script type = "text/javascript" src = "js/vue_computedprops.js"></script>
</body>
</html>
vue_computeprops.js
var vm = new Vue({
el: '#computed_props',
data: {
firstname :"",
lastname :"",
birthyear : ""
},
computed :{
getfullname : function(){
return this.firstname +" "+ this.lastname;
}
}
})
Ici, nous avons créé .htmlfichier avec prénom et nom. Prénom et nom est une zone de texte liée à l'aide des propriétés prénom et nom.
Nous appelons la méthode calculée getfullname, qui renvoie le prénom et le nom saisis.
computed :{
getfullname : function(){
return this.firstname +" "+ this.lastname;
}
}
Lorsque nous tapons dans la zone de texte, la même chose est renvoyée par la fonction, lorsque les propriétés firstname ou lastname sont modifiées. Ainsi, avec l'aide de computed, nous n'avons rien à faire de spécifique, comme se souvenir d'appeler une fonction. Avec calculé, il est appelé par lui-même, car les propriétés utilisées à l'intérieur changent, c'est-à-dire le prénom et le nom.
La même chose est affichée dans le navigateur suivant. Tapez dans la zone de texte et la même chose sera mise à jour à l'aide de la fonction calculée.
Maintenant, essayons de comprendre la différence entre une méthode et une propriété calculée. Les deux sont des objets. Il y a des fonctions définies à l'intérieur, qui renvoie une valeur.
Dans le cas de méthode, nous l'appelons comme une fonction, et pour le calcul comme une propriété. En utilisant l'exemple suivant, comprenons la différence entre la méthode et la propriété calculée.
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "computed_props">
<h1 style = "background-color:gray;">Random No from computed property: {{getrandomno}}</h1>
<h1>Random No from method: {{getrandomno1()}}</h1>
<h1>Random No from method : {{getrandomno1()}}</h1>
<h1 style = "background-color:gray;">Random No from computed property: {{getrandomno}}</h1>
<h1 style = "background-color:gray;">Random No from computed property: {{getrandomno}}</h1>
<h1 style = "background-color:gray;">Random No from computed
property: {{getrandomno}}</h1>
<h1>Random No from method: {{getrandomno1()}}</h1>
<h1>Random No from method: {{getrandomno1()}}</h1>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#computed_props',
data: {
name : "helloworld"
},
methods: {
getrandomno1 : function() {
return Math.random();
}
},
computed :{
getrandomno : function(){
return Math.random();
}
}
});
</script>
</body>
</html>
Dans le code ci-dessus, nous avons créé une méthode appelée getrandomno1 et une propriété calculée avec une fonction getrandomno. Les deux donnent des nombres aléatoires en utilisant Math.random ().
Il s'affiche dans le navigateur comme indiqué ci-dessous. La méthode et la propriété calculée sont appelées plusieurs fois pour montrer la différence.
Si nous regardons les valeurs ci-dessus, nous verrons que les nombres aléatoires renvoyés par la propriété calculée restent les mêmes quel que soit le nombre de fois où elle est appelée. Cela signifie qu'à chaque fois qu'il est appelé, la dernière valeur est mise à jour pour tous. Alors que pour une méthode, c'est une fonction, par conséquent, chaque fois qu'elle est appelée, elle retourne une valeur différente.
Obtenir / Définir dans les propriétés calculées
Dans cette section, nous allons découvrir les fonctions get / set dans les propriétés calculées à l'aide d'un exemple.
Exemple
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "computed_props">
<input type = "text" v-model = "fullname" />
<h1>{{firstName}}</h1>
<h1>{{lastName}}</h1>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#computed_props',
data: {
firstName : "Terry",
lastName : "Ben"
},
methods: {
},
computed :{
fullname : {
get : function() {
return this.firstName+" "+this.lastName;
}
}
}
});
</script>
</body>
</html>
Nous avons défini une zone de saisie qui est liée à fullname, qui est une propriété calculée. Il renvoie une fonction appeléeget, qui donne le nom complet, c'est-à-dire le prénom et le nom. De plus, nous avons affiché le prénom et le nom comme -
<h1>{{firstName}}</h1>
<h1>{{lastName}}</h1>
Vérifions la même chose dans le navigateur.
Maintenant, si nous changeons le nom dans la zone de texte, nous verrons que la même chose n'est pas reflétée dans le nom affiché dans la capture d'écran suivante.
Ajoutons la fonction setter dans la propriété calculée fullname.
<html>
<head>
<title>VueJs Instance</title>
<script type = "text/javascript" src = "js/vue.js"></script>
</head>
<body>
<div id = "computed_props">
<input type = "text" v-model = "fullname" />
<h1>{{firstName}}</h1>
<h1>{{lastName}}</h1>
</div>
<script type = "text/javascript">
var vm = new Vue({
el: '#computed_props',
data: {
firstName : "Terry",
lastName : "Ben"
},
methods: {
},
computed :{
fullname : {
get : function() {
return this.firstName+" "+this.lastName;
},
set : function(name) {
var fname = name.split(" ");
this.firstName = fname[0];
this.lastName = fname[1]
}
}
}
});
</script>
</body>
</html>
Nous avons ajouté la fonction set dans la propriété calculée fullname.
computed :{
fullname : {
get : function() {
return this.firstName+" "+this.lastName;
},
set : function(name) {
var fname = name.split(" ");
this.firstName = fname[0];
this.lastName = fname[1]
}
}
}
Il a le nom comme paramètre, qui n'est rien d'autre que le nom complet dans la zone de texte. Plus tard, il est divisé en espace et le prénom et le nom sont mis à jour. Maintenant, lorsque nous exécutons le code et modifions la zone de texte, la même chose sera affichée dans le navigateur. Le prénom et le nom seront mis à jour en raison de la fonction définie. La fonction get renvoie le prénom et le nom, tandis que la fonction set les met à jour, si quelque chose est modifié.
Maintenant, tout ce qui est tapé dans la zone de texte correspond à ce qui est affiché comme indiqué dans la capture d'écran ci-dessus.