亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解vue2.0監(jiān)聽屬性的使用心得及搭配計算屬性的使用

 更新時間:2018年07月18日 08:32:25   作者:瘋狂的小標點  
這篇文章主要介紹了vue2.0之監(jiān)聽屬性的使用心得及搭配計算屬性的使用,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

我們在工作中常常需要監(jiān)聽某一個屬性值的變化,這個時候我們就需要用到了監(jiān)聽屬性watch,在這里我總結(jié)watch屬性的三種場景使用希望對你有所幫助:

1.基礎(chǔ)版監(jiān)聽:

場景如下:輸入框輸入你的年齡,如果年齡在0-15歲提示信息:你還是個小孩,如果年齡在 15-25歲,提示信息:你已經(jīng)是個少年,如果年齡在25歲以上,提示信息:你已經(jīng)長大了。根據(jù)需求配合監(jiān)聽屬性我們得到下面的代碼:

<template>
 <div id="app">
  年齡:<input type="number" v-model="age"><br>
  提示信息:<span>{{infoMsg}}</span>
 </div>
</template>

<script>
export default {
 data() {
  return {
   age: "",
   infoMsg:""
  }
 },
 watch:{
  age:function(val,oldval){
   if(val>0 && val<15){
    this.infoMsg="你還是個小孩"
   }else if(val>15 && val<25){
    this.infoMsg="你已經(jīng)是個少年"
   }else{
    this.infoMsg="你已經(jīng)長大了"
   }
  }
 }
}
</script>

這里需要特別說明一下的是:堅挺屬性方法中的兩個參數(shù)分別代表的含義:第一個val是當面正在監(jiān)聽的屬性的值,oldval是屬性改變之前的值,由于這是形參的原因,參數(shù)的名字可以自己定義,但是但是參數(shù)所代表的含義是不會變化的。

2.進階版監(jiān)聽:

下面我們改變一下需求:基礎(chǔ)規(guī)則不變,但是因為后臺數(shù)據(jù)庫的更改(畫個圈圈咀咒他)我們需要提交一個這樣的數(shù)據(jù)結(jié)構(gòu)

 data() {
  return {
   info: {
    age: ""
   },
   infoMsg: ""
  };
 },

由于我們監(jiān)聽的是對象info中的屬性age值的變化,所以我們需要使用到的是深度監(jiān)聽,具體代碼如下:

<template>
 <div id="app">
  年齡:<input type="number" v-model="info.age"><br>
  提示信息:<span>{{infoMsg}}</span>
 </div>
</template>

<script>
export default {
 data() {
  return {
   info: {
    age: ""
   },
   infoMsg: ""
  };
 },
 watch: {
  info: {
   handler: function(val, oldval) {
    var that = this;
    if (val.age > 0 && val.age < 15) {
     that.infoMsg = "你還是個小孩";
    } else if (val.age > 15 && val.age < 25) {
     that.infoMsg = "你已經(jīng)是個少年";
    } else {
     that.infoMsg = "你已經(jīng)長大了";
    }
   },
   deep: true
  }
 }
};
</script>

在這里需要注意的有兩點:1,這里的function不能使用箭頭函數(shù)替代,如果使用箭頭函數(shù)的話,this的指向會是全局。2,你會注意到這里多加入一個屬性是deep,它的含義表示是否開啟深度監(jiān)聽,如果開啟值為true,反之為false。

3.最高級監(jiān)聽:

針對第二個案例不知道你有沒有發(fā)現(xiàn)一個問題:我們監(jiān)聽的是一個對象里面某個屬性的變化,但是如果當這個對象里面有很多個值的時候,雖然也可以使用第二種方法進行監(jiān)聽,但是這將會是對資源的一種極大的浪費,身為一個嚴謹?shù)某绦騿T(微笑臉),絕對不能允許這樣的事情發(fā)生,所以我們可以結(jié)合computed(計算屬性)對上面的代碼進行優(yōu)化:

<template>
 <div id="app">
  年齡:<input type="number" v-model="info.age"><br>
  提示信息:<span>{{infoMsg}}</span>
 </div>
</template>
<script>
export default {
 data() {
  return {
   info: {
    age: "",
    name: "",
    hobit: ""
   },
   infoMsg: ""
  };
 },
 computed: {
  ageval: function() {
   return this.info.age;
  }
 },
 watch: {
  ageval: {
   handler: function(val, oldval) {
    var that = this;
    if (val > 0 && val < 15) {
     that.infoMsg = "你還是個小孩";
    } else if (val > 15 && val < 25) {
     that.infoMsg = "你已經(jīng)是個少年";
    } else {
     that.infoMsg = "你已經(jīng)長大了";
    }
   },
   deep: true
  }
 }
};
</script>

通過上面的我們看出,這次我們監(jiān)聽的是計算屬性ageval,而計算屬性返回的則是info對象中age的值,與第二次的代碼進行比較我們可以發(fā)現(xiàn)兩次代碼中監(jiān)聽的一個是對象info,一個是info對象中age的值,性能大大增強,這就是我們期待的結(jié)果了。

總結(jié)

以上所述是小編給大家介紹的vue2.0監(jiān)聽屬性的使用心得及搭配計算屬性的使用,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 淺談Vue.js之初始化el以及數(shù)據(jù)的綁定說明

    淺談Vue.js之初始化el以及數(shù)據(jù)的綁定說明

    今天小編就為大家分享一篇淺談Vue.js之初始化el以及數(shù)據(jù)的綁定說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 基于Vue實現(xiàn)拖拽效果

    基于Vue實現(xiàn)拖拽效果

    這篇文章主要介紹了基于Vue實現(xiàn)拖拽效果,文中給大家介紹了clientY pageY screenY layerY offsetY的區(qū)別講解,需要的朋友可以參考下
    2018-04-04
  • 簡單說說如何使用vue-router插件的方法

    簡單說說如何使用vue-router插件的方法

    這篇文章主要介紹了如何使用vue-router插件的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • element-ui el-dialog嵌套table組件,ref問題及解決

    element-ui el-dialog嵌套table組件,ref問題及解決

    這篇文章主要介紹了element-ui el-dialog嵌套table組件,ref問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Vue基礎(chǔ)教程之條件渲染和列表渲染

    Vue基礎(chǔ)教程之條件渲染和列表渲染

    Vue會盡可能高效地渲染元素,通常會復用已有元素而不是從頭開始渲染。這么做會使Vue變得非???下面這篇文章主要給大家介紹了Vue基礎(chǔ)教程之條件渲染和列表渲染的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • 基于Vue技術(shù)實現(xiàn)遞歸組件的方法

    基于Vue技術(shù)實現(xiàn)遞歸組件的方法

    這篇文章主要為大家詳細介紹了基于Vue技術(shù)實現(xiàn)遞歸組件的方法 ,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Vue2 監(jiān)聽屬性改變watch的實例代碼

    Vue2 監(jiān)聽屬性改變watch的實例代碼

    今天小編就為大家分享一篇Vue2 監(jiān)聽屬性改變watch的實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • vue實現(xiàn)上傳圖片添加水印(升級版)

    vue實現(xiàn)上傳圖片添加水印(升級版)

    這篇文章主要為大家詳細介紹了vue實現(xiàn)上傳圖片添加水印的升級版,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • vue實現(xiàn)圖片路徑轉(zhuǎn)二進制文件流(binary)

    vue實現(xiàn)圖片路徑轉(zhuǎn)二進制文件流(binary)

    這篇文章主要介紹了vue實現(xiàn)圖片路徑轉(zhuǎn)二進制文件流(binary),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 深入淺析Vue中的slots/scoped slots

    深入淺析Vue中的slots/scoped slots

    這篇文章主要介紹了Vue中的slots/scoped slots,本文實例代碼相結(jié)合的形式給大家介紹了slots的工作原理,需要的朋友可以參考下
    2018-04-04

最新評論