日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

淺談vue.watch的觸發(fā)條件是什么

瀏覽:80日期:2022-11-04 17:27:50

很多人習慣用watch,但是卻很少有人知道watch的真正觸發(fā)條件。如果不是對vue原理了如指掌,請謹慎使用watch。

示例1,下面會觸發(fā)watch 嗎?

<script> new Vue({ data() { return { city: {id: 1, name: ’Beijing’} } }, watch: { city() { console.log(’city changed’) } }, created() { this.city = {id: 1, name: ’Beijing’} } })</script>

會觸發(fā),因為在created方法里面重新給city賦值了一個對象,city前后的指向不同了

示例2:

<script> new Vue({ data() { return { city: {id: 1, name: ’Beijing’} } }, watch: { city() { console.log(’city changed’) } }, created() { this.city.name = ’Shanghai’ } })</script>

不會觸發(fā), 因為created方法執(zhí)行之后, city的指向沒有變

如果我們期望捕獲這種更新,應該這樣寫代碼:

watch: { city: { handler: () => console.log(’city changed’), deep: true }}

將選項deep設為true能讓vue捕獲對象內(nèi)部的變化。

下面討論一下watch一個數(shù)組:

<script>new Vue({ el: ’#body’, data() { return { cities: [’Beijing’, ’Tianjin’] } }, watch: { cities() { console.log(’cities changed’) } }})</script>

那下面哪些操作會觸發(fā)cities的watch回調(diào)呢?

this.cities = [’Beijing’, ’Tianjin’]this.cities.push(’Xiamen’)this.cities = this.cities.slice(0, 1)this.cities.pop();this.cities.sort((a,b)=>a.localeCompare(b));this.cities[0] = ’Shenzhen’this.cities.splice(0, 1)this.cities.length = 0

答案是只有最后三行不會觸發(fā)。

補充知識:vue 深度watch與watch立即觸發(fā)回調(diào)

基礎用法

搜索框輸入搜索關鍵字的時候,可以自動觸發(fā)搜索,此時除了監(jiān)聽搜索框的change事件之外,我們也可以通過watch監(jiān)聽搜索關鍵字的變化。

<template> <div> <span>搜索</span> <input v-model='searchVal' /> </div></template><script>export default { data() { return { searchVal: ’’ } }, watch: { // 在值發(fā)生變化之后,重新加載數(shù)據(jù) searchVal(newValue, oldValue) { if (newValue !== oldValue) { this.loadData() } } }, methods: { loadData() { // 重新加載數(shù)據(jù),此處需要通過函數(shù)防抖 } }}</script>

立即觸發(fā)

通過上面的代碼,現(xiàn)在已經(jīng)可以在值發(fā)生變化的時候觸發(fā)加載數(shù)據(jù)了,但是如果要在頁面初始化時候加載數(shù)據(jù),我們還需要在created或者mounted生命周期鉤子里面再次調(diào)用loadData方法。不過,現(xiàn)在可以不用這樣寫了,通過配置watch的立即觸發(fā)屬性,就可以滿足了。

export default { watch: { // 在值發(fā)生變化之后,重新加載數(shù)據(jù) searchValue: { // 通過handler來監(jiān)聽屬性變化, 初次調(diào)用 newValue為''空字符串, oldValue為 undefined handler(newValue, oldValue) { if (newValue !== oldValue) { this.loadData() } }, // 配置立即執(zhí)行屬性 immediate: true } }}

深度監(jiān)聽

一個表單頁面,需求希望用戶在修改表單的任意一項之后,表單頁面就需要變更為被修改狀態(tài)。如果按照上例中watch的寫法,那么我們就需要去監(jiān)聽表單每一個屬性,太麻煩了,這時候就需要用到watch的深度監(jiān)聽deep

export default { data() { return { formData: { name: ’’, sex: ’’, age: 0, deptId: ’’ } } }, watch: { // 在值發(fā)生變化之后,重新加載數(shù)據(jù) formData: { // 需要注意,因為對象引用的原因, newValue和oldValue的值一直相等 handler(newValue, oldValue) { // 在這里標記頁面編輯狀態(tài) }, // 通過指定deep屬性為true, watch會監(jiān)聽對象里面每一個值的變化 deep: true } }}

隨時監(jiān)聽,隨時取消,了解一下$watch

有這樣一個需求,有一個表單,在編輯的時候需要監(jiān)聽表單的變化,如果發(fā)生變化則保存按鈕啟用,否則保存按鈕禁用。

這時候?qū)τ谛略霰韱蝸碚f,可以直接通過watch去監(jiān)聽表單數(shù)據(jù)(假設是formData),如上例所述,但對于編輯表單來說,表單需要回填數(shù)據(jù),這時候會修改formData的值,會觸發(fā)watch,無法準確的判斷是否啟用保存按鈕。現(xiàn)在你就需要了解一下$watch

export default { data() { return { formData: { name: ’’, age: 0 } } }, created() { this.$_loadData() }, methods: { // 模擬異步請求數(shù)據(jù) $_loadData() { setTimeout(() => { // 先賦值 this.formData = { name: ’子君’, age: 18 } // 等表單數(shù)據(jù)回填之后,監(jiān)聽數(shù)據(jù)是否發(fā)生變化 const unwatch = this.$watch( ’formData’, () => { console.log(’數(shù)據(jù)發(fā)生了變化’) }, { deep: true } ) // 模擬數(shù)據(jù)發(fā)生了變化 setTimeout(() => { this.formData.name = ’張三’ }, 1000) }, 1000) } }}

根據(jù)上例可以看到,我們可以在需要的時候通過this.$watch來監(jiān)聽數(shù)據(jù)變化。那么如何取消監(jiān)聽呢,上例中this.$watch返回了一個值unwatch,是一個函數(shù),在需要取消的時候,執(zhí)行 unwatch()即可取消

以上這篇淺談vue.watch的觸發(fā)條件是什么就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
在线视频精品| 日韩av福利| 亚洲欧美日韩精品一区二区| 韩国三级一区| 色婷婷精品视频| 日韩一区二区三区免费播放| 日韩在线短视频| 久久久久久免费视频| 国产尤物精品| 欧美日韩精品一本二本三本 | 一区二区精品伦理...| 精品视频97| 国产白浆在线免费观看| 日本国产精品| 黄色aa久久| 国产99精品| 丝袜亚洲另类欧美| 日本特黄久久久高潮| 国产精品成人**免费视频 | 久久精品国产网站| 黄在线观看免费网站ktv| 亚洲天堂久久| 亚洲深深色噜噜狠狠爱网站| 日本视频一区二区| 狠狠久久伊人| 激情欧美丁香| 日韩精品第一| 超碰99在线| 欧美理论视频| 日韩精品a在线观看91| 国产精品欧美日韩一区| 色欧美自拍视频| 在线国产一区二区| 青青草国产成人99久久| 精品国产一区二区三区av片| 99精品国产一区二区三区| 亚洲一区二区动漫| 国产精品成人3p一区二区三区| 91综合网人人| 欧美天堂亚洲电影院在线观看| 日本伊人午夜精品| 成人污污视频| 国产午夜久久| 亚洲精品美女91| 国产aⅴ精品一区二区三区久久 | 毛片在线网站| 亚洲日本欧美| 老司机精品久久| 久久影院一区二区三区| 欧美搞黄网站| 欧美久久香蕉| 香蕉视频亚洲一级| 美日韩精品视频| 久久精品资源| 视频一区在线视频| 成人亚洲一区| 中文字幕视频精品一区二区三区| 国产成人精品一区二区免费看京 | 日韩专区精品| 日日夜夜免费精品| 日韩欧美中文| 日韩1区2区日韩1区2区| 久久精品高清| 欧美日韩调教| 欧美日韩高清| 国产一区二区三区免费在线 | 嫩呦国产一区二区三区av| 在线精品视频在线观看高清| 美女视频网站久久| 蜜桃视频一区二区三区| 亚洲伊人av| 欧美日本不卡高清| 在线视频精品| 欧美黄色网页| 国产区精品区| 亚洲一区二区三区无吗| 亚洲涩涩在线| 久久激情av| 亚洲免费婷婷| 久久精品导航| 韩日一区二区| 911精品国产| 亚洲综合三区| 欧美成人午夜| 亚洲欧洲美洲av| 久久久久观看| 国产毛片精品久久| 综合五月婷婷| 黄色成人91| 三上悠亚国产精品一区二区三区| 国产精品亚洲一区二区在线观看| 美女网站久久| 欧美日韩视频一区二区三区| 国产精品原创| 久久中文欧美| 国产精品v一区二区三区| 亚洲+小说+欧美+激情+另类| 尤物网精品视频| 91精品蜜臀一区二区三区在线| 精品美女久久| 国产精品伊人| 久久国产婷婷国产香蕉| 亚洲久久在线| 蜜臀av一区二区在线免费观看| 亚洲欧美一区在线| 精品欧美久久| 99久久亚洲精品蜜臀| 亚洲精品永久免费视频| 日产精品一区二区| 精品国产亚洲一区二区三区在线 | 国产精品资源| 日韩av中文字幕一区二区三区| 亚洲精品1区| 九九综合在线| 亚洲福利一区| 日韩午夜av| 黄色成人在线网址| 一区在线免费观看| 久久精品主播| 欧美不卡高清| 免费不卡中文字幕在线| 久久高清免费| 亚洲午夜视频| 在线成人直播| 最新亚洲一区| 在线视频亚洲欧美中文| 在线看片日韩| 伊人国产精品| 日本在线视频一区二区| 日韩激情一区二区| 国产日产精品_国产精品毛片 | 美腿丝袜亚洲一区| 麻豆精品蜜桃视频网站| 欧美精品成人| 日本一区二区高清不卡| 日韩电影免费在线观看| 日韩在线短视频| 亚洲男女av一区二区| 亚洲一二三区视频| 久久国产精品免费精品3p | 久久精品官网| 伊人精品视频| 日本不卡在线视频| 麻豆精品少妇| 桃色一区二区| 欧美日韩黑人| 亚洲午夜国产成人| 久久狠狠久久| 国产精品蜜芽在线观看| 99精品在线观看| 免费看日韩精品| 欧美日韩一区二区三区不卡视频 | 亚洲精品进入| 国产精品久久久久久久久免费高清| 精品亚洲自拍| 亚洲国产专区| 日本在线不卡视频一二三区| 国产精品一区二区三区av麻| 精品日韩一区| 99久久夜色精品国产亚洲1000部| 欧美在线综合| 国产乱人伦精品一区| 亚洲天堂资源| 三级在线观看一区二区| 欧美综合精品| 一区二区三区四区日本视频| 91久久黄色| 国产美女精品视频免费播放软件| 国产91在线精品| 午夜亚洲福利在线老司机| 欧美日韩va| 一区二区三区四区在线看| 日韩精品一区二区三区中文在线| 久久爱www成人| 亚洲小说欧美另类婷婷| 少妇精品久久久一区二区三区| 麻豆久久一区| 99国产精品久久久久久久| 欧美日韩1区2区3区| 日韩精品免费一区二区三区| 视频在线观看91| 毛片在线网站| 日本综合精品一区| 日本午夜大片a在线观看| 免播放器亚洲一区| 成人日韩av| 亚洲91在线| 日韩在线观看| 青青草国产成人99久久| 91精品国产成人观看| 青青草伊人久久| 久久精品高清| 老鸭窝一区二区久久精品| 亚洲永久字幕| 激情综合婷婷| 综合亚洲色图| 久久亚洲国产| 你懂的网址国产 欧美| 国产精品女主播一区二区三区| 国产精久久久|