看到這個標(biāo)題就知道這篇文章接下來要講的內(nèi)容,我們在使用vue的時候methods、watch、computed這三個特性一定經(jīng)常使用,因?yàn)樗鼈兪欠浅5挠杏茫菦]有徹底的理解它們的區(qū)別和各自的使用場景,也很難用好它們,希望接下來的介紹為你答疑解惑。
玉樹網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)建站成立于2013年到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。
computed
我們先來看計(jì)算屬性:computed,光看名字也知道是用來干什么的,計(jì)算屬性當(dāng)然是用來計(jì)算的,但是是怎么計(jì)算的呢?計(jì)算屬性有兩個顯著的特點(diǎn):
我們來看一個相關(guān)的例子:
<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的時候,經(jīng)常會碰到要對data的值進(jìn)行操作的情況,為了方便,總是會有人直接在模版中對data的值進(jìn)行計(jì)算操作,就像我上面例子中寫的在模版中將數(shù)組轉(zhuǎn)化為字符串,這樣寫有問題嗎?語法沒有問題,但是在模版中使用太多的計(jì)算,維護(hù)會是個問題,換個人來看代碼的時候會很痛苦,這種寫法就好像在html中插入js的邏輯運(yùn)算,可維護(hù)性極差。另外一個展示的就是computed的響應(yīng)式依賴的問題,當(dāng)我們調(diào)用getDate的時候返回的Date.now()返回的是一個非響應(yīng)式的依賴因此getDate返回的值不會變。
應(yīng)用場景
看了computed的特點(diǎn)之后,那么它的應(yīng)用場景是什么呢?個人看法,但不限于以下場景:
methods
methods大家應(yīng)該都會用,是vue中的方法屬性,所有的方法調(diào)用都會寫到這里面,大家用的最多也是在累似@click這樣事件調(diào)用中使用,但是很多人都忽視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在模版中常常使用的一個場景,當(dāng)模版中的某個循環(huán)的值需要進(jìn)行一定邏輯運(yùn)算時,這時候你就可以使用methods方法,將對應(yīng)的值傳入,然后計(jì)算出結(jié)果返回到模版顯示,這個時候用computed是沒法實(shí)現(xiàn)的,computed中你無法傳參,methods和computed除了這個不一樣之外,還有就是在methods中的計(jì)算是不會做緩存的,也就是你調(diào)用多少次就會計(jì)算多少次,相對computed的開銷要大一些。
watch
偵聽屬性是專門用來觀察和響應(yīng)vue實(shí)例上的數(shù)據(jù)變動,能使用watch屬性的場景基本上都可以使用computed屬性,而且computed屬性開銷小,性能高,因此能使用computed就盡量使用computed屬性,那么watch屬性是不是就沒用武之地了呢?當(dāng)執(zhí)行異步操作的時候你可能就必須用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'
}
})上述例子中,當(dāng)在模版中調(diào)用getObj.a時,如果沒有setTimeout這異步操作,直接返回一個值是可以直接在模版中顯示的,但是由于加異步操作就會導(dǎo)致沒有返回值同時調(diào)用對象的屬性,就會報錯,而調(diào)用obj1.a卻不一樣,模版會先顯示hello,然后在觸發(fā)了watch屬性時,setTimeout觸發(fā),一秒鐘之后模版會顯示helloword,這就watch中可以使用異步函數(shù),而computed不行的原因
總結(jié)
希望看了這篇文章能對你區(qū)分methods、computed、watch的用法能有所幫助。
這篇文章如果有錯誤或不嚴(yán)謹(jǐn)?shù)牡胤剑瑲g迎批評指正,如果喜歡,歡迎點(diǎn)贊收藏
文章名稱:Vue中的methods、watch、computed的區(qū)別
文章URL:http://chinadenli.net/article0/gdseio.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、手機(jī)網(wǎng)站建設(shè)、全網(wǎng)營銷推廣、做網(wǎng)站、靜態(tài)網(wǎng)站、移動網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)