<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        Vue中的methods、watch、computed的區別

        來源:懂視網 責編:小采 時間:2020-11-27 22:03:27
        文檔

        Vue中的methods、watch、computed的區別

        Vue中的methods、watch、computed的區別:看到這個標題就知道這篇文章接下來要講的內容,我們在使用vue的時候methods、watch、computed這三個特性一定經常使用,因為它們是非常的有用,但是沒有徹底的理解它們的區別和各自的使用場景,也很難用好它們,希望接下來的介紹為你答疑解惑。 comput
        推薦度:
        導讀Vue中的methods、watch、computed的區別:看到這個標題就知道這篇文章接下來要講的內容,我們在使用vue的時候methods、watch、computed這三個特性一定經常使用,因為它們是非常的有用,但是沒有徹底的理解它們的區別和各自的使用場景,也很難用好它們,希望接下來的介紹為你答疑解惑。 comput

        看到這個標題就知道這篇文章接下來要講的內容,我們在使用vue的時候methods、watch、computed這三個特性一定經常使用,因為它們是非常的有用,但是沒有徹底的理解它們的區別和各自的使用場景,也很難用好它們,希望接下來的介紹為你答疑解惑。

        computed

        我們先來看計算屬性:computed,光看名字也知道是用來干什么的,計算屬性當然是用來計算的,但是是怎么計算的呢?計算屬性有兩個顯著的特點:

      1. 計算屬性計算時所依賴的屬性一定是響應式依賴,否則計算屬性不會執行
      2. 計算屬性是基于依賴進行緩存的,就是說在依賴沒有更新的情況,調用計算屬性并不會重新計算,可以減少開銷
      3. 我們來看一個相關的例子:

        <div id="app">
         <div>{{ arr.join('') }}</div>
         <div>{{ arr1 }}</div>
         <div>{{ getDate }}</div>
         <div>{{ getDate1 }}</div>
        </div>
        var app = new Vue({
         el: '#app',
         data: {
         date: '',
         arr: ['a', 'b', 'c']
         },
         computed: {
         getDate () {
         return Date.now()
         },
         getDate1 () {
         return this.date
         },
         arr1 () {
         return this.arr.join('')
         }
         },
         created () {
         setInterval(() => {
         this.date = Date.now()
         }, 1000)
         }
        })

        看上面的例子,我們在寫vue的時候,經常會碰到要對data的值進行操作的情況,為了方便,總是會有人直接在模版中對data的值進行計算操作,就像我上面例子中寫的在模版中將數組轉化為字符串,這樣寫有問題嗎?語法沒有問題,但是在模版中使用太多的計算,維護會是個問題,換個人來看代碼的時候會很痛苦,這種寫法就好像在html中插入js的邏輯運算,可維護性極差。另外一個展示的就是computed的響應式依賴的問題,當我們調用getDate的時候返回的Date.now()返回的是一個非響應式的依賴因此getDate返回的值不會變。

        應用場景

        看了computed的特點之后,那么它的應用場景是什么呢?個人看法,但不限于以下場景:

      4. 復雜的渲染數據計算,用computed計算屬性可以減少一定計算開銷,增加可維護性
      5. 從Vuex Store中收集相關信息,對Vuex中的數據做計算的時候的要特別注意computed的緩存屬性,在對Vuex中的對象值進行屬性修改的時候,并不會觸發computed的中值的變化,這時需要Object.assign({},obj)對依賴對象進行跟新返回一個新對象觸發依賴跟新
      6. 表單校驗,這個應用場景應該是比較常見的,利用正則表達式對每個表單項的實時監控,判斷表單是否可以提交
      7. methods

        methods大家應該都會用,是vue中的方法屬性,所有的方法調用都會寫到這里面,大家用的最多也是在累似@click這樣事件調用中使用,但是很多人都忽視methods的另一個用法,就是在模版中使用methods,下面來看一個例子:

        <div id="app">
         <div v-for="(item, idx) in arr">
         {{ matching(item) }}
         </div>
        </div>
        var app = new Vue({
         el: '#app',
         data: {
         arr: ['a', 'b', 'c'],
         obj: {a: 'hello', b: 'world'}
         },
         methods: {
         matching (key) {
         if (this.obj[key]) {
         return this.obj[key]
         } else {
         return 'not found'
         }
         }
         }
        })

        上面的例子就是methods在模版中常常使用的一個場景,當模版中的某個循環的值需要進行一定邏輯運算時,這時候你就可以使用methods方法,將對應的值傳入,然后計算出結果返回到模版顯示,這個時候用computed是沒法實現的,computed中你無法傳參,methods和computed除了這個不一樣之外,還有就是在methods中的計算是不會做緩存的,也就是你調用多少次就會計算多少次,相對computed的開銷要大一些。

        watch

        偵聽屬性是專門用來觀察和響應vue實例上的數據變動,能使用watch屬性的場景基本上都可以使用computed屬性,而且computed屬性開銷小,性能高,因此能使用computed就盡量使用computed屬性,那么watch屬性是不是就沒用武之地了呢?當執行異步操作的時候你可能就必須用watch而不是computed了,下面看一個例子:

        <div id="app">
         <div>{{ obj1.a }}</div>
        </div>
        var app = new Vue({
         el: '#app',
         data: {
         obj: {a: 'hello'},
         obj1: {a: 'hello'},
         test: 'aaa'
         },
         computed: {
         getObj () {
         setTimeout(() => {
         this.obj.a = this.test + 'word'
         return this.obj
         }, 1000)
         }
         },
         watch: {
         test () {
         setTimeout(() => {
         this.obj1.a = this.test + 'word'
         }, 1000)
         }
         },
         mounted () {
         this.test = 'hello'
         }
        })

        上述例子中,當在模版中調用getObj.a時,如果沒有setTimeout這異步操作,直接返回一個值是可以直接在模版中顯示的,但是由于加異步操作就會導致沒有返回值同時調用對象的屬性,就會報錯,而調用obj1.a卻不一樣,模版會先顯示hello,然后在觸發了watch屬性時,setTimeout觸發,一秒鐘之后模版會顯示helloword,這就watch中可以使用異步函數,而computed不行的原因

        總結

        希望看了這篇文章能對你區分methods、computed、watch的用法能有所幫助。

        這篇文章如果有錯誤或不嚴謹的地方,歡迎批評指正,如果喜歡,歡迎點贊收藏

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        Vue中的methods、watch、computed的區別

        Vue中的methods、watch、computed的區別:看到這個標題就知道這篇文章接下來要講的內容,我們在使用vue的時候methods、watch、computed這三個特性一定經常使用,因為它們是非常的有用,但是沒有徹底的理解它們的區別和各自的使用場景,也很難用好它們,希望接下來的介紹為你答疑解惑。 comput
        推薦度:
        標簽: 區別 VUE watch
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲国产成人爱av在线播放| 91频在线观看免费大全| 国产一卡二卡≡卡四卡免费乱码| 99久久亚洲精品无码毛片| 大地影院MV在线观看视频免费| 亚洲日韩人妻第一页| 黄色免费在线网址| 亚洲AV无码专区日韩| 免费播放国产性色生活片| 亚洲第一页综合图片自拍| 久青草国产免费观看| 亚洲精品无码av天堂| 中国一级毛片免费看视频| 亚洲va国产va天堂va久久| 久久中文字幕免费视频| 亚洲黄色在线网站| 精品久久久久国产免费| 狠狠入ady亚洲精品| 亚洲中文字幕无码久久2017 | 白白色免费在线视频| 亚洲毛片不卡av在线播放一区| 国产精品高清免费网站| 亚洲AV无码成人专区片在线观看| 久久黄色免费网站| 亚洲一区二区三区国产精华液| 女人18毛片水真多免费看| 精品无码一级毛片免费视频观看| 亚洲AV永久无码精品成人| 37pao成人国产永久免费视频| 亚洲久热无码av中文字幕| 亚洲美女高清一区二区三区| 久久成人免费电影| 亚洲日韩精品国产3区| 亚洲黄黄黄网站在线观看| 91精品啪在线观看国产线免费| 亚洲jizzjizz在线播放久| 人人狠狠综合久久亚洲高清| baoyu777永久免费视频 | 99热这里有免费国产精品| 亚洲一区二区三区乱码在线欧洲| 国产福利免费在线观看|