VueJS - Interfaccia reattiva

VueJS fornisce opzioni per aggiungere reattività alle proprietà, che vengono aggiunte dinamicamente. Considera che abbiamo già creato l'istanza di vue e dobbiamo aggiungere la proprietà watch. Può essere fatto come segue:

Esempio

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "app">
         <p style = "font-size:25px;">Counter: {{ counter }}</p>
         <button @click = "counter++" style = "font-size:25px;">Click Me</button>
      </div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#app',
            data: {
               counter: 1
            }
         });
         vm.$watch('counter', function(nval, oval) {
            alert('Counter is incremented :' + oval + ' to ' + nval + '!');
         });
         setTimeout(
            function(){
               vm.counter = 20;
            },2000
         );
      </script>
   </body>
</html>

C'è un contatore di proprietà definito come 1 nell'oggetto dati. Il contatore viene incrementato quando si fa clic sul pulsante.

L'istanza di Vue è già creata. Per aggiungere orologio ad esso, dobbiamo farlo come segue:

vm.$watch('counter', function(nval, oval) {
   alert('Counter is incremented :' + oval + ' to ' + nval + '!');
});

Dobbiamo usare $ watch per aggiungere watch fuori dall'istanza di vue. È stato aggiunto un avviso che mostra la modifica del valore per la proprietà del contatore. C'è anche una funzione timer aggiunta, cioè setTimeout, che imposta il valore del contatore su 20.

setTimeout(
   function(){
      vm.counter = 20;
   },2000
);

Ogni volta che il contatore viene modificato, l'avviso dal metodo dell'orologio verrà attivato come mostrato nello screenshot seguente.

VueJS non è in grado di rilevare l'aggiunta e l'eliminazione di proprietà. Il modo migliore è dichiarare sempre le proprietà, che devono essere reattive in anticipo nell'istanza di Vue. Nel caso in cui abbiamo bisogno di aggiungere proprietà in fase di esecuzione, possiamo utilizzare i metodi Vue global, Vue.set e Vue.delete.

Vue.set

Questo metodo aiuta a impostare una proprietà su un oggetto. Viene utilizzato per aggirare la limitazione che Vue non può rilevare le aggiunte di proprietà.

Sintassi

Vue.set( target, key, value )

Dove,

target: può essere un oggetto o un array

chiave: può essere una stringa o un numero

valore: può essere qualsiasi tipo

Diamo un'occhiata a un esempio.

Esempio

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "app">
         <p style = "font-size:25px;">Counter: {{ products.id }}</p>
         <button @click = "products.id++" style = "font-size:25px;">Click Me</button>
      </div>
      <script type = "text/javascript">
         var myproduct = {"id":1, name:"book", "price":"20.00"};
         var vm = new Vue({
            el: '#app',
            data: {
               counter: 1,
               products: myproduct
            }
         });
         vm.products.qty = "1";
         console.log(vm);
         vm.$watch('counter', function(nval, oval) {
            alert('Counter is incremented :' + oval + ' to ' + nval + '!');
         });
      </script>
   </body>
</html>

Nell'esempio sopra, c'è una variabile myproduct creata all'inizio utilizzando la seguente parte di codice.

var myproduct = {"id":1, name:"book", "price":"20.00"};

Viene fornito all'oggetto dati nell'istanza di Vue come segue:

var vm = new Vue({
   el: '#app',
   data: {
      counter: 1,
      products: myproduct
   }
});

Considera che vogliamo aggiungere un'altra proprietà all'array myproduct, dopo aver creato l'istanza di Vue. Può essere fatto come segue:

vm.products.qty = "1";

Vediamo l'output nella console.

Come visto sopra, nei prodotti viene aggiunta la quantità. I metodi get / set, che fondamentalmente aggiungono reattività, sono disponibili per ID, nome e prezzo e non disponibili per qty.

Non possiamo ottenere la reattività semplicemente aggiungendo vue object. VueJS vuole principalmente che tutte le sue proprietà siano create all'inizio. Tuttavia, nel caso in cui sia necessario aggiungerlo in un secondo momento, possiamo usare Vue.set. Per questo, dobbiamo impostarlo usando vue global, cioè Vue.set.

Esempio

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "app">
         <p style = "font-size:25px;">Counter: {{ products.id }}</p>
         <button @click = "products.id++" style = "font-size:25px;">Click Me</button>
      </div>
      <script type = "text/javascript">
         var myproduct = {"id":1, name:"book", "price":"20.00"};
         var vm = new Vue({
            el: '#app',
            data: {
               counter: 1,
               products: myproduct
            }
         });
         Vue.set(myproduct, 'qty', 1);
         console.log(vm);
         vm.$watch('counter', function(nval, oval) {
            alert('Counter is incremented :' + oval + ' to ' + nval + '!');
         });
      </script>
   </body>
</html>

Abbiamo utilizzato Vue.set per aggiungere la qty all'array utilizzando la seguente parte di codice.

Vue.set(myproduct, 'qty', 1);

Abbiamo consolato l'oggetto vue e di seguito è riportato l'output.

Ora, possiamo vedere il get / set per qty aggiunto usando Vue.set.

Vue.delete

Questa funzione viene utilizzata per eliminare dinamicamente la proprietà.

Esempio

Vue.delete( target, key )

Dove,

target: può essere un oggetto o un array

chiave: può essere una stringa o un numero

Per eliminare qualsiasi proprietà, possiamo utilizzare Vue.delete come nel codice seguente.

Esempio

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "app">
         <p style = "font-size:25px;">Counter: {{ products.id }}</p>
         <button @click = "products.id++" style = "font-size:25px;">Click Me</button>
      </div>
      <script type = "text/javascript">
         var myproduct = {"id":1, name:"book", "price":"20.00"};
         var vm = new Vue({
            el: '#app',
            data: {
               counter: 1,
               products: myproduct
            }
         });
         Vue.delete(myproduct, 'price');
         console.log(vm);
         vm.$watch('counter', function(nval, oval) {
            alert('Counter is incremented :' + oval + ' to ' + nval + '!');
         });
      </script>
   </body>
</html>

Nell'esempio precedente, abbiamo utilizzato Vue.delete per eliminare il prezzo dall'array utilizzando la seguente parte di codice.

Vue.delete(myproduct, 'price');

Di seguito è riportato l'output, che vediamo nella console.

Dopo l'eliminazione, possiamo vedere solo l'ID e il nome poiché il prezzo viene eliminato. Possiamo anche notare che i metodi get / set vengono eliminati.