Vue監聽屬性和計算屬性
一、watch監聽屬性
這個屬性用來監視某個數據的變化,並觸發相應的回調函數執行。
基本用法添加watch
屬性,值為一個對象。對象的屬性名就是要監視的數據,屬性值為回調函數,每當這個屬性名對應的值發生變化,就會觸發該回調函數執行。
回調函數有2個參數:
newVal
,數據發生改變後的值。oldVal
,數據發生改變前的值。
計數器:
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title></title> <script src="./js/vue.js"></script> </head> <body> <div id="app"> <div>計數器{{ shu }}</div> <span>改變前: {{ov}}</span> <span>改變後: {{nv}}</span> <br /> <button @click="shu++">加一</button> </div> <script> var vm = new Vue({ el: '#app', data: { shu:1, ov:0, nv:0 }, methods:{ } }) vm.$watch("shu",function(nval,oval){ vm.$data.ov = oval vm.$data.nv = nval }) </script> </body> </html>
添加監聽,同時將計數器改變前的值賦值給變量ov
,將改變後的值賦值給變量nv
vm.$watch("shu",function(nval,oval){ vm.$data.ov = oval vm.$data.nv = nval })
1.購物車
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script src="./js/vue.js"></script> </head> <body> <div id="app"> <table> <tr> <th>序號</th> <th>商品名稱</th> <th>商品價格</th> <th>購買數量</th> <th>操作</th> </tr> <tr v-for="sp in sps"> <td>{{ sp.id }}</td> <td>{{ sp.name }}</td> <td>{{ sp.money }}</td> <td> <button v-on:click="sp.sum=sp.sum-1">-</button> {{ sp.sum }} <button v-on:click="sp.sum=sp.sum+1">+</button> </td> <td> <button v-on:click="sp.sum=0">重置</button> </td> </tr> </table> <div > 總價:{{ getmaney() }} </div> </div> <script> var vm = new Vue({ el: '#app', data: { sps:[ { id:1, name:"蘋果13", money:6000, sum:1 }, { id:2, name:"蘋果12", money:5000, sum:1 }, { id:3, name:"蘋果11", money:4000, sum:1 } ] }, methods:{ getmaney:function(){ var m=0; for(var x=0;x<this.sps.length;x++){ m=m+this.sps[x].money*this.sps[x].sum; } return m; } } }) </script> </body> </html>
得出總的費用:
getmaney:function(){ var m=0; for(var x=0;x<this.sps.length;x++){ m=m+this.sps[x].money*this.sps[x].sum; } return m; }
2.全選與取消全選
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script src="./js/vue.js"></script> </head> <body> <div id="app"> <input type="checkbox" id="a" value="a" v-model="che"/> <label for="a">a</label> <input type="checkbox" id="b" value="b" v-model="che"/> <label for="b">b</label> <input type="checkbox" v-model="checked" id="bok" v-on:change="ckall()" /> <label for="box">全選</label> </div> <script> var vm = new Vue({ el: '#app', data: { checked:false, che:[], shuzu:["a","b"] }, methods:{ ckall:function(){ //全選狀態 if(this.checked){ this.che = this.shuzu }else{ //取消全選 this.che=[] } } }, watch:{ "che":function(){ //判斷是否全選 if(this.che.length == this.shuzu.length){ this.checked=true }else{ this.checked=false } } } }) </script> </body> </html>
二、計算屬性
1.computed
特點:
- 在
computed
屬性對象中定義計算屬性的方法,在頁面上使用{{方法名}}來顯示計算結果。 - 通過
getter/setter
來顯示和監視屬性數據。 - 計算屬性存在緩存,多次讀取隻執行一次
getter
。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script src="./js/vue.js"></script> </head> <body> <div id="app"> <p>{{ mess }}</p> <p>{{ remess }}</p> <p>{{ mess.split('').reverse().join('') }}</p> </div> <script> var vm = new Vue({ el: '#app', data:{ mess:'abcd' }, computed: { remess:function(){ return this.mess.split('').reverse().join('') } } }) </script> </body> </html>
2.methods
computed
基於它的依賴緩存,隻有相關依賴發生改變時才會重新取值。而使用methods
,在重新渲染的時候,函數總會重新調用執行。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script src="./js/vue.js"></script> </head> <body> <div id="app"> <input v-model="mess" /> <p>{{ mess }}</p> <p>{{ remess }}</p> <p>{{ remess2() }}</p> </div> <script> var vm = new Vue({ el: '#app', data:{ mess:'abcd' }, computed: { remess:function(){ return this.mess.split('').reverse().join('') } }, methods: { remess2:function(){ return this.mess.split('').reverse().join('') } } }) </script> </body> </html>
3.setter
當頁面獲取某個數據的時候,先會在data裡面找,找不到就會去計算屬性裡面找,在計算屬性裡獲取數據時會自動執行get方法,同時也提供瞭set方法。computed
屬性默認隻有getter
,不過在需要時也可以提供一個setter。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script src="./js/vue.js"></script> </head> <body> <div id="app"> <p>{{ site }}</p> </div> <script> var vm = new Vue({ el: '#app', data: { name: 'xiaowang', cls:'01' }, computed:{ site:{ get: function(){ return this.name+' '+this.cls }, set: function(Value){ var names = Value.split('|') this.name = names[0] this.cls = names[1] } } } }) vm.site = 'xiaowang|01'; document.write('name:'+vm.name); document.write('<br>'); document.write('class:'+vm.cls); </script> </body> </html>
到此這篇關於Vue監聽屬性和計算屬性的文章就介紹到這瞭,更多相關Vue監聽和計算屬性內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Vue之計算屬性詳解
- Vue父子組件數據雙向綁定(父傳子、子傳父)及ref、$refs、is、:is的使用與區別
- vue實現計數器簡單制作
- vue中v-for指令完成列表渲染
- 詳解Vue.js Class與Style綁定