成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

淺談vue.watch的觸發條件是什么

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

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

示例1,下面會觸發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>

會觸發,因為在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>

不會觸發, 因為created方法執行之后, city的指向沒有變

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

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

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

下面討論一下watch一個數組:

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

那下面哪些操作會觸發cities的watch回調呢?

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

答案是只有最后三行不會觸發。

補充知識:vue 深度watch與watch立即觸發回調

基礎用法

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

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

立即觸發

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

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

深度監聽

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

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

隨時監聽,隨時取消,了解一下$watch

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

這時候對于新增表單來說,可以直接通過watch去監聽表單數據(假設是formData),如上例所述,但對于編輯表單來說,表單需要回填數據,這時候會修改formData的值,會觸發watch,無法準確的判斷是否啟用保存按鈕。現在你就需要了解一下$watch

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

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

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

標簽: Vue
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产成人一区在线| 国产精品原创巨作av| 首页欧美精品中文字幕| 91视频一区二区三区| 91精品国产综合久久久久久漫画| 亚洲成人自拍偷拍| 一区精品久久| 国产欧美一区二区精品性| 蜜桃视频第一区免费观看| 国产精品一区亚洲| 国产精品美女www爽爽爽| 国产a久久麻豆| 色婷婷精品大在线视频| 亚洲欧洲日韩综合一区二区| 欧美xxx在线观看| 制服丝袜亚洲播放| 精品在线播放免费| 欧美日韩成人激情| 久久精品国产精品亚洲综合| 老鸭窝毛片一区二区三区| 国产精品国产三级国产普通话蜜臀| 本田岬高潮一区二区三区| 日韩欧美中文一区二区| 国产一区福利在线| 欧美无人高清视频在线观看| 青青草97国产精品免费观看| 久久久久久亚洲精品杨幂换脸 | 91小视频在线| 久久亚洲二区三区| 91一区一区三区| 久久精子c满五个校花| 99亚偷拍自图区亚洲| 久久亚洲私人国产精品va媚药| 波波电影院一区二区三区| www日韩大片| 欧美va天堂| 成人免费在线播放视频| 亚洲三级影院| 亚洲国产日日夜夜| 男人的天堂亚洲| 亚洲高清在线精品| 一本色道**综合亚洲精品蜜桃冫| 日本视频在线一区| 欧美另类一区二区三区| 国产成人在线视频网址| 亚洲精品一区二区在线观看| 99re这里都是精品| 欧美国产禁国产网站cc| 亚洲精品国产系列| 亚洲1区2区3区4区| 色94色欧美sute亚洲线路一久| 免费观看在线综合色| 欧美另类高清zo欧美| 成人av第一页| 日本一区二区三区国色天香 | 日韩高清中文字幕一区| 欧美在线播放高清精品| 激情综合一区二区三区| 日韩欧美成人一区| 欧美午夜不卡| 亚洲动漫第一页| 欧美日韩在线综合| 国产一区二区伦理片| 日韩午夜在线影院| 欧美网站在线| 午夜精品久久久久久久蜜桃app| 欧洲色大大久久| 成人av影院在线| 亚洲欧美日韩精品久久久久| 久久精品日韩| 国产成人亚洲综合a∨猫咪| www激情久久| 日韩一级精品| 久久精品国产精品亚洲精品| 日韩写真欧美这视频| 女人色偷偷aa久久天堂| 亚洲另类中文字| 欧美在线视频你懂得| 国产成人亚洲精品狼色在线| 亚洲国产精品黑人久久久| 国产欧美一区二区色老头| 九九热在线视频观看这里只有精品 | 黄色欧美日韩| 五月天欧美精品| 欧美成人伊人久久综合网| 亚洲国产精品久久久久久女王| 日韩高清欧美激情| 精品久久久久久综合日本欧美 | 国产精品自在在线| 国产区在线观看成人精品| 国产亚洲欧美另类一区二区三区| 另类综合日韩欧美亚洲| 久久综合九色综合97婷婷| 黄色av一区| 蜜臀精品久久久久久蜜臀| 26uuu国产在线精品一区二区| 一区二区日本视频| 国产精品香蕉一区二区三区| 国产精品成人免费精品自在线观看| 久久一区二区三区超碰国产精品| 国产成人免费xxxxxxxx| 国产精品久久三| 欧美日韩在线不卡| 精品69视频一区二区三区Q| 捆绑紧缚一区二区三区视频| 国产午夜精品美女毛片视频| 久久天天综合| 色综合天天综合网国产成人综合天| 亚洲影视在线观看| 亚洲精品一区二区三区蜜桃下载| 国产农村妇女精品一区二区| 成人午夜私人影院| 亚洲国产视频在线| 国产欧美日韩在线视频| 欧美喷水一区二区| 亚洲亚洲精品三区日韩精品在线视频| 免费成人小视频| 国产精品久久网站| 欧美一区二区三区免费| 国产欧美日韩在线播放| 成人国产在线观看| 日韩综合小视频| 中文在线免费一区三区高中清不卡| 一本色道久久加勒比精品| 欧美国内亚洲| 美女视频第一区二区三区免费观看网站| 国产欧美精品一区二区色综合 | 成人av在线网| 免费在线观看精品| 亚洲欧美在线观看| 欧美一级午夜免费电影| 乱人伦精品视频在线观看| 欧美视频在线观看| 成人高清伦理免费影院在线观看| 日韩av一区二区在线影视| ●精品国产综合乱码久久久久| 26uuu久久综合| 欧美日韩国产免费| 久久精品欧美| 一区二区三区国产在线| 欧美一区二视频在线免费观看| 国产主播一区二区| 日韩综合小视频| 亚洲日本一区二区| 久久色.com| 欧美一级久久久| 欧美无砖砖区免费| 色欲综合视频天天天| 亚洲最黄网站| 欧美日韩成人一区二区三区| 成人成人成人在线视频| 国产原创一区二区三区| 日本欧美一区二区三区乱码 | 久久久亚洲高清| 欧美日韩精品系列| 免费在线亚洲| 亚洲欧洲另类| 激情综合在线| 欧美区日韩区| 91女人视频在线观看| 国产99精品视频| 欧美性videosxxxxx| 欧美一级日韩一级| 欧美精品久久天天躁| 色综合久久中文字幕| 亚洲国产日韩综合久久精品| 欧美激情资源网| 日韩欧美国产一区二区在线播放 | 日韩精品一二三| 亚洲第一二三四区| 亚洲一区二区三区不卡国产欧美| 亚洲乱码国产乱码精品精的特点| 亚洲视频综合在线| 18欧美亚洲精品| 国产精品久久午夜| 中文字幕亚洲欧美在线不卡| 国产精品三级视频| 亚洲欧洲精品一区二区| 国产日韩欧美三区| 蜜桃久久av| 久久久噜噜噜| 欧洲精品在线观看| 欧美日韩在线电影| 91精品国产综合久久久久| 91麻豆精品国产91久久久| 欧美人狂配大交3d怪物一区| 91精品国产欧美一区二区成人| 欧美一级二级三级蜜桃| 精品入口麻豆88视频| 久久亚洲捆绑美女| 欧美激情一区二区三区| 亚洲国产成人自拍| 成人免费在线视频观看| 亚洲在线成人精品| 日本亚洲免费观看| 国产精品一卡二卡| 白白色亚洲国产精品| 欧美影视一区| 伊人久久大香线蕉综合热线| 亚洲日本激情|