国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

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

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

很多人習(xí)慣用watch,但是卻很少有人知道watch的真正觸發(fā)條件。如果不是對vue原理了如指掌,請謹(jǐn)慎使用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ā),因?yàn)樵赾reated方法里面重新給city賦值了一個(gè)對象,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ā), 因?yàn)閏reated方法執(zhí)行之后, city的指向沒有變

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

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

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

下面討論一下watch一個(gè)數(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ā)。

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

基礎(chǔ)用法

搜索框輸入搜索關(guān)鍵字的時(shí)候,可以自動觸發(fā)搜索,此時(shí)除了監(jiān)聽搜索框的change事件之外,我們也可以通過watch監(jiān)聽搜索關(guā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ā)生變化的時(shí)候觸發(fā)加載數(shù)據(jù)了,但是如果要在頁面初始化時(shí)候加載數(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)聽

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

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

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

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

這時(shí)候?qū)τ谛略霰韱蝸碚f,可以直接通過watch去監(jiān)聽表單數(shù)據(jù)(假設(shè)是formData),如上例所述,但對于編輯表單來說,表單需要回填數(shù)據(jù),這時(shí)候會修改formData的值,會觸發(fā)watch,無法準(zhǔn)確的判斷是否啟用保存按鈕。現(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ù)上例可以看到,我們可以在需要的時(shí)候通過this.$watch來監(jiān)聽數(shù)據(jù)變化。那么如何取消監(jiān)聽呢,上例中this.$watch返回了一個(gè)值unwatch,是一個(gè)函數(shù),在需要取消的時(shí)候,執(zhí)行 unwatch()即可取消

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

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 九九九热在线精品免费全部 | 国产成人免费高清视频 | 精品国产欧美一区二区三区成人 | 欧美日本综合一区二区三区 | 国产美女做爰免费视频网址 | 国产三级日本三级日产三 | 亚洲制服丝袜美腿亚洲一区 | 国内自拍在线观看 | 亚洲一区成人 | 男女毛片免费视频看 | 精品国产品香蕉在线观看 | 97公开免费视频 | 久久在线观看免费视频 | 成人在线91 | 男人女人做黄刺激性视频免费 | 日韩三级黄色 | 美女很黄很黄是免费的·无遮挡网站 | 免费观看欧美成人h | 国产精品亚洲四区在线观看 | 牛人国产偷窥女洗浴在线观看 | 夜夜骚视频 | 99视频在线看观免费 | 在线观看偷拍视频一区 | 日本高清毛片视频在线看 | 久久国产精品无码网站 | 欧美日韩在线观看一区二区 | 国产精品免费视频能看 | 寂寞午夜影院 | 欧美日韩在线播一区二区三区 | 热er99久久6国产精品免费 | 亚洲欧美久久精品1区2区 | 欧美做爰野外在线视频观看 | 国产一级高清 | 一级一级一片免费高清 | 亚洲成a人在线播放www | 免费的三级网站 | 国产成在线观看免费视频成本人 | 韩国在线精品福利视频在线观看 | 自拍偷自拍亚洲精品一区 | 亚洲男人的天堂久久香蕉 | 国产真实生活伦对白 |