中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue計算屬性computed、事件、監聽器watch的使用講解

發布時間:2020-10-18 23:21:43 來源:腳本之家 閱讀:270 作者:muzidigbig 欄目:web開發

一.計算屬性(computed)

<template>
  <div class="box">
    <h2>計算屬性</h2>
    <hr>
    <!-- 直接渲染得到數據 -->
    <p><input type="text" v-model="message"></p>
    <!-- 對data的數據進行簡單的操作
    這樣有一個不好的地方就是后期對頁面數據的維護不是那么方便 -->
    <p>{{message.toUpperCase()}}</p>
    <!-- 通過計算屬性改變mesage進行渲染 -->
    <p>{{computedMessage}}</p>
    <hr>
    <!-- 通過事件來改變屬性 -->
    <span>{{message}}</span><button @click="changeMessage()">點擊改變</button>
    <hr>
  </div>
</template>
<script>
export default {
  data() {
    return {
      message: 'Hello world!',
      passw2: 'sss',
    }
  },
  // computed屬性是return返回值,在使用的時候只使用函數名不是調用函數
  computed:{
    computedMessage(){
      return this.message.split('')
    }
  },
  methods:{
    changeMessage(){
      this.message = this.computedMessage+'altman'
    }
  },
}
</script>

這里需要注意的是computed中的函數名不能和所操作data中的數據一樣;computed中的函數名相當于是操作data數據后的新數據,在模塊中直接使用這個函數名即可實現對data中數據改變的渲染。

二.監聽器(watch)

首先確認 watch是一個對象,一定要當成對象來用。

對象就有鍵,有值。

第一種 鍵:就是你要監聽的那個數據,比如說$route,這個就是要監控路由的變化。或者是data中的某個變量。

值可以是函數:就是當你監控的家伙變化時,需要執行的函數,這個函數有兩個形參,第一個是改變后的新值,第二個是改變之前的值。

第二種  值也可以是函數名:不過這個函數名要用單引號來包裹。(不常用)

第三種情況厲害了(監聽的那個數據值是一個對象):

值是包括選項的對象:選項包括有三個。

  •     第一個handler:其值是一個回調函數。即監聽到變化時應該執行的函數。
  •     第二個是deep:其值是true或false;確認是否深入監聽。(一般監聽時是不能監聽到對象屬性值的變化的,數組的值變化可以聽到。)
  •     第三個是immediate:其值是true或false;確認是否以當前的初始值執行handler的函數。

用法一:基礎用法

<template>
  <div class="box">
    <h2>監聽器</h2>
    <label>二次密碼:</label>
    <input v-model="watchMsg" />
  </div>
</template>
<script>
export default {
  data() {
    return {
      message: 'Hello world!',
      watchMsg: '我是監聽操作',
    }
  },
  watch:{
    watchMsg(newVal,oldVal){
      console.log('newVal:'+newVal,'oldVal:'+oldVal);
    },
  }
}
</script>

用法二:handler方法和immediate屬性

<template>
  <div class="box">
    <h2>監聽器</h2>
    <label>二次密碼:</label>
    <input v-model="watchMsg" />
  </div>
</template>
<script>
export default {
  data() {
    return {
      message: 'Hello world!',
      watchMsg: '我是監聽操作',
    }
  },
  watch:{
    watchMsg: {
      handler(newVal,oldVal){
        console.log('newVal:'+newVal,'oldVal:'+oldVal);
      },
      immediate:true,
    }
  }
}
</script>

注意到handler了嗎,我們給 watchMsg綁定了一個handler方法,之前我們寫的 watch 方法其實默認寫的就是這個handler,Vue.js會去處理這個邏輯,最終編譯出來其實就是這個handler。

而immediate:true代表如果在 wacth 里聲明了watchMsg之后,就會立即先去執行里面的handler方法,如果為 false就跟我們以前的效果一樣,不會在綁定的時候就執行。

用法三:

deep屬性

watch 里面還有一個屬性 deep,默認值是 false,代表是否深度監聽,比如我們 data 里有一個obj屬性/數組:

<template>
  <div class="box">
    <h2>監聽器</h2>
    <label>二次密碼:</label>
    <input v-model="obj.watchMsg" />
  </div>
</template>
<script>
export default {
  data() {
    return {
      message: 'Hello world!',
      obj:{
        watchMsg: '我是監聽操作',
      }
    }
  },
  watch:{
    // 需要注意的是這里的監聽對象也需要變化
    'obj.watchMsg': {
      handler(newVal,oldVal){
        console.log('newVal:'+newVal,'oldVal:'+oldVal);
      },
      immediate:true,
      deep:true,
    }
  }
}
</script>

2、數組的watch

<template>
  <div class="box">
    <h2>監聽器</h2>
    <p>{{array}}</p>
    <button @click='addArray()'>點擊改變數組</button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      message: 'Hello world!',
      array:['mu','zi','dig','big']
    }
  },
  watch:{
    // 需要注意的是這里所監聽的對象應該是數組
    array:{
      handler(newVal,oldVal){
        console.log(newVal+'--'+oldVal)
      },
      deep:true,
      immediate:true,
    }
  },
  methods:{
    addArray() {
      this.array.push('66')
    }
  }
}
</script>

3、數組中對象的watch

<template>
  <div class="box">
    <h2>監聽器</h2>
    <ul>
      <li v-for="(item,index) in arrayObj" :key="item.id">{{index}}--{{item.name}}---<input type="text" v-model="item.age" @keydown="change(index)"></li>
    </ul>
    <hr>
    <ul>
      <li v-for="(item,index) in arrayObj" :key="item.id">{{index}}--{{item.name}}---{{item.age}}</li>
    </ul>
  </div>
</template>
<script>
export default {
  data() {
    return {
      arrayObj:[
        {name:'張三',age:'23'},
        {name:'李四',age:'22'}
      ],
    }
  },
  watch:{
    // 需要注意的是這里所監聽的對象應該是數組
    arrayObj:{
      handler(newVal,oldVal){
        console.log(newVal+'--'+oldVal)
      },
      deep:true,
      immediate:true,
    }
  },
  methods:{
    change(i) {
      // console.log(this.changeValue)
      this.arrayObj[i].age = this.arrayObj[i].age
    }
  }
}
</script>

4、對象具體屬性的watch[活用computed]

<template>
  <div class="box">
    <h2>監聽器</h2>
    <p>{{obj.name}}</p>
    <input type="text" v-model="obj.name" name="" id="">
    <p>{{newName}}</p>
  </div>
</template>
<script>
export default {
  data() {
    return {
      obj:{name:'muzi',age:'23'},
    }
  },
  computed:{
    newName(){
      return this.obj.name.toUpperCase();
    }
  },
  watch:{
    newName(newVal,oldVal){
      console.log(newVal+'--'+oldVal)
    },
    // newName:{
    //   handler(newVal,oldVal){
    //     console.log(newVal+'--'+oldVal)
    //   },
    //   deep:true,
    //   immediate:true,
    // }
  },
}
</script>

從效果圖上可以看出,計算屬性最好使用在更改數據上然后進行渲染;先進行的計算屬性再進行的監聽。

vue計算屬性computed、事件、監聽器watch的使用講解

若有不足請多多指教!希望給您帶來幫助!

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武邑县| 中西区| 客服| 新密市| 郑州市| 阿巴嘎旗| 平乡县| 龙陵县| 沾化县| 酉阳| 磐安县| 托克托县| 米易县| 墨脱县| 旌德县| 南召县| 毕节市| 清涧县| 兴安盟| 镇宁| 陇川县| 扎囊县| 阳西县| 天柱县| 大理市| 儋州市| 祁门县| 金昌市| 时尚| 黄平县| 利津县| 视频| 临桂县| 扎兰屯市| 新竹市| 麻城市| 龙口市| 萨嘎县| 读书| 仙居县| 滁州市|