Vue computed與watch用法區(qū)分
computed用法
- 響應(yīng)式緩存
- 每一個(gè)計(jì)算屬性都會(huì)被緩存起來,只要計(jì)算屬性所依賴的屬性發(fā)生變化,計(jì)算屬性就會(huì)重新執(zhí)行,視圖也會(huì)更新
- computed方法里面的屬性不能在Date中定義
- .具有緩存性,頁面重新渲染值不變化,,計(jì)算屬性會(huì)立即返回之前的計(jì)算結(jié)果,而不必再次執(zhí)行函數(shù)
data: {
firstName: 'one',
lastName: 'two'
},
//計(jì)算方法
computed: {
allname:{
//回調(diào)函數(shù) 當(dāng)需要讀取當(dāng)前屬性值是執(zhí)行,根據(jù)相關(guān)數(shù)據(jù)計(jì)算并返回當(dāng)前屬性的值
get() {//
return this.firstName + ' ' + this.lastName
},
//監(jiān)視當(dāng)前屬性值的變化,當(dāng)屬性值發(fā)生變化時(shí)執(zhí)行,更新相關(guān)的屬性數(shù)據(jù)
set(val){
const names = val.split(' ');
this.firstName = names[0];
this.lastName = names[1];
}
}
},
watch用法
- 需要在數(shù)據(jù)變化時(shí)執(zhí)行異步或開銷較大的操作時(shí),這個(gè)方式是最有用的
- 應(yīng)用:監(jiān)聽props,$emit或本組件的值執(zhí)行異步操作
- 無緩存性,頁面重新渲染時(shí)值不變化也會(huì)執(zhí)行
watch: {
被監(jiān)聽的數(shù)據(jù): {
handler(新值, 舊值) {
相關(guān)代碼邏輯...
}
}
}
- 被監(jiān)聽的數(shù)據(jù):data中定義的數(shù)據(jù)
- 新值:該數(shù)據(jù)改變后的新值;
- 舊值:該數(shù)據(jù)改變之前的值。
常見應(yīng)用
- 監(jiān)聽本組件計(jì)算和監(jiān)聽
- 計(jì)算或監(jiān)聽父?jìng)髯拥膒rops值
- 分為簡(jiǎn)單數(shù)據(jù)類型和復(fù)雜數(shù)據(jù)類型監(jiān)聽,監(jiān)聽方法如上watch的使用
- 監(jiān)聽vuex的state或者getters值的變化
computed:{
stateDemo(){
return this.$store.state.demoState;
}
}
watch:{
stateDemo(){
console.log('vuex變化啦')
}
}
常見錯(cuò)誤
當(dāng)修改父組件傳過來的值,會(huì)報(bào)錯(cuò)
props:['listShop'],
data(){
return{}
},
created(){
this.listShop=30
}
報(bào)錯(cuò),錯(cuò)誤是說的避免直接修改父組件傳入的值,因?yàn)闀?huì)改變父組件的值
解決方法1,如果傳的是簡(jiǎn)單類型,就在data中重新定義一個(gè)變量,改變指向,復(fù)雜類型不行,復(fù)雜類型存的是指針
//不會(huì)有任何報(bào)錯(cuò),也不會(huì)影響父組件!
props:['listShop'],
data(){
return{
listShopChild:this.listShop //改變指向
}
},
created(){
this.listShopChild=30
}
但如果是復(fù)雜類型,因?yàn)榇娴氖侵羔?,賦值給新變量也會(huì)改變?cè)甲兞恐?/p>
方法:
1.手動(dòng)深度克隆
2.Object.assign,只會(huì)對(duì)只是一級(jí)屬性復(fù)制,比淺拷貝多深拷貝了一層而已,所以還是無法達(dá)到深度克隆的目的.
3.強(qiáng)大的JSON.stringify和JSON.parse
4.直接用computed改變
//數(shù)組深度克隆:
var x = [1,2,3];
var y = [];
for (var i = 0; i < x.length; i++) {
y[i]=x[i];
}
console.log(y); //[1,2,3]
y.push(4);
console.log(y); //[1,2,3,4]
console.log(x); //[1,2,3]
//對(duì)象深度克隆:
var x = {a:1,b:2};
var y = {};
for(var i in x){
y[i] = x[i];
}
console.log(y); //Object {a: 1, b: 2}
y.c = 3;
console.log(y); //Object {a: 1, b: 2, c: 3}
console.log(x); //Object {a: 1, b: 2}
//函數(shù)深度克隆
//為什么函數(shù)可以直接賦值克隆?
//由于函數(shù)對(duì)象克隆之后的對(duì)象會(huì)單獨(dú)復(fù)制一次并存儲(chǔ)實(shí)際數(shù)據(jù),因此并不會(huì)影響克隆之前的對(duì)象。所以采用簡(jiǎn)單的復(fù)制“=”即可完成克隆。
var x = function(){console.log(1);};
var y = x;
y = function(){console.log(2);};
x(); //1
y(); //2
//方法三 const obj1 = JSON.parse(JSON.stringify(obj));
//方法四
computed:{
listShopChild(){
return this.listShop
}
}
到此這篇關(guān)于Vue computed與watch用法區(qū)分的文章就介紹到這了,更多相關(guān)Vue computed與watch內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue+Element-ui實(shí)現(xiàn)登錄注冊(cè)表單
這篇文章主要為大家詳細(xì)介紹了vue+Element-ui實(shí)現(xiàn)登錄注冊(cè)表單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11
element-plus結(jié)合sortablejs實(shí)現(xiàn)table行拖拽效果
使用element-plus的el-table組件創(chuàng)建出來的table,結(jié)合sortable.js實(shí)現(xiàn)table行拖動(dòng)排序,文中有詳細(xì)的代碼示例供大家參考,具有一定的參考價(jià)值,感興趣的同學(xué)可以自己動(dòng)手試一試2023-10-10
vue3為什么要用proxy替代defineProperty
這篇文章主要介紹了vue3為什么要用proxy替代defineProperty,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10

