【技術(shù)】vue中watch跟computed使用的實(shí)例

1、watch鉤子函數(shù)監(jiān)聽數(shù)據(jù)的變化

watch 的一個(gè)特點(diǎn)是煞躬,最初綁定的時(shí)候是不會執(zhí)行的(firstName的值在data定義時(shí)賦予的值),要等到 firstName 改變時(shí)才執(zhí)行監(jiān)聽計(jì)算逸邦。

<div>
<p>FullName: {{fullName}}</p>
<p>FirstName: <input type="text" v-model="firstName"></p>
</div>

new Vue({
 el: '#root',
 data: {
   firstName: 'Dawei',
   lastName: 'Lou',
   fullName: ''
},
watch: {
   firstName(newName, oldName) {
      this.fullName = newName + ' ' + this.lastName;
   }
}
})

handler方法和immediate屬性

這時(shí)候需要增加immediate屬性恩沛,設(shè)置為true,如果不需要就設(shè)置false缕减,那就是初始化不會監(jiān)聽變化雷客,這時(shí)候需要將watch部分的代碼修改如何.

watch: {
 firstName: {
  handler(newName, oldName) {
   this.fullName = newName + ' ' + this.lastName;
  },
  // 代表在wacth里聲明了firstName這個(gè)方法之后立即先去執(zhí)行handler方法
  immediate: true
 }
}

注意:

在watch中,如果對對象進(jìn)行監(jiān)聽桥狡,只有對象obj被重新賦值時(shí)搅裙,watch才會被監(jiān)聽到,這個(gè)時(shí)候無法對obj里面的屬性的變化進(jìn)行監(jiān)聽裹芝,這時(shí)候部逮,我們可以只對這個(gè)屬性監(jiān)聽,可以是使用字符串形式監(jiān)聽

watch: {
 'obj.a': {
  handler(newName, oldName) {
   console.log('obj.a changed');
  },
  immediate: true,
  // deep: true
 }
}

應(yīng)用場景:

可以只用watch來監(jiān)聽數(shù)據(jù)的變化實(shí)時(shí)更新數(shù)據(jù)的變化

<template>
 <input v-model="value" /> // 搜索框
</template>
<script>
export default {
 data(){
  return {
    value: '' // 值
  }
 },
 watch:{
   value(val){ // 實(shí)時(shí)監(jiān)聽數(shù)據(jù)變化
     this.wat_fun(val)
   }
 }嫂易, 
 methods:{
   wat_fun(val){ // 這里可以調(diào)用搜索api接口
    console.log(val)
   }
 }
}
</script>

2兄朋、computed鉤子函數(shù)監(jiān)聽數(shù)據(jù)的變化

 讀取computed里面的值還是用this.changeVal

3、watch和computed各自處理的數(shù)據(jù)關(guān)系場景不同 (來源于)
知識點(diǎn)1:watch擅長處理的場景:一個(gè)數(shù)據(jù)影響多個(gè)數(shù)據(jù)
知識點(diǎn)2:computed擅長處理的場景:一個(gè)數(shù)據(jù)受多個(gè)數(shù)據(jù)影響

對于watch怜械,我們先從一個(gè)場景說起

在《海賊王》里面颅和,主角團(tuán)隊(duì)的名稱叫做:“草帽海賊團(tuán)”
所以我們把船員依次稱為:
草帽海賊團(tuán)索隆,草帽海賊團(tuán)娜美,以此類推。缕允。峡扩。
我們希望:當(dāng)船團(tuán)名稱發(fā)生變更的時(shí)候,這艘船上所有船員的名字一起變更U媳尽教届!
例如:
有一天,船長路飛為了加強(qiáng)團(tuán)隊(duì)建設(shè),弘揚(yáng)海賊文化巍佑,決定“草帽海賊團(tuán)”改名為“橡膠海賊團(tuán)”(路飛是橡膠惡魔果實(shí)能力者)
我們代碼如下:

var vm = new Vue({
     el: '#app',
     /*
      data選項(xiàng)中的數(shù)據(jù):
      1.haiZeiTuan_Name --> 海賊團(tuán)名稱
      2.船員的名稱 = 海賊團(tuán)名稱(草帽海賊團(tuán)) + 船員名稱(例如索萝钋ā)

  這些數(shù)據(jù)里存在這種關(guān)系:
  (多個(gè))船員名稱數(shù)據(jù) --> 依賴于 --> (1個(gè))海賊團(tuán)名稱數(shù)據(jù)
  一個(gè)數(shù)據(jù)變化 ---> 多個(gè)數(shù)據(jù)全部變化
 */
 data: {
  haiZeiTuan_Name: '草帽海賊團(tuán)',
  suoLong: '草帽海賊團(tuán)索隆',
  naMei: '草帽海賊團(tuán)娜美',
  xiangJiShi: '草帽海賊團(tuán)香吉士'
 },
 /*
  在watch中,一旦haiZeiTuan_Name(海賊團(tuán)名稱)發(fā)生改變
  data選項(xiàng)中的船員名稱全部會自動(dòng)改變 (suoLong萤衰,naMei堕义,xiangJiShi)
  并把它們打印出來
 */
 watch: {
  haiZeiTuan_Name: function (newName) {
   this.suoLong = newName + '索隆'
   this.naMei = newName + '娜美'
   this.xiangJiShi = newName + '香吉士'
   console.log(this.suoLong)
   console.log(this.naMei)
   console.log(this.xiangJiShi)
  }
 }
})

// 更改watch選項(xiàng)中監(jiān)控的主數(shù)據(jù)
vm.haiZeiTuan_Name = '橡膠海賊團(tuán)'

于是船員們的稱號前綴都被統(tǒng)一修改了!(原本是“草帽海賊團(tuán)”)
但是我們的路飛船長又突發(fā)奇想:我這么喜歡吃肉脆栋,干脆我們叫做“肉肉海賊團(tuán)”好了吧倦卖!
我們把最下面的代碼改為:
// 更改watch選項(xiàng)中監(jiān)控的主數(shù)據(jù)
vm.haiZeiTuan_Name = '肉肉海賊團(tuán)'

而computed擅長處理的場景:一個(gè)數(shù)據(jù)受多個(gè)數(shù)據(jù)影響

我們再從一個(gè)場景說起
路飛的全名叫做:蒙奇-D-路飛,他想成為海賊王椿争,但路飛的爺爺卡普(海軍英雄)因此感到非常惱怒怕膛,于是把“路飛”改成了叫“海軍王”,希望他能改變志向
代碼如下:

var vm = new Vue({
 el: '#app',
 /*
  data選項(xiàng)中的數(shù)據(jù):firstName秦踪,secName,thirdName
  computed監(jiān)控的數(shù)據(jù):lufei_Name
  兩者關(guān)系: lufei_Name = firstName + secName + thirdName
  所以等式右邊三個(gè)數(shù)據(jù)任一改變褐捻,都會直接修改 lufei_Name
 */
 data: {
  // 路飛的全名:蒙奇·D·路飛
  firstName: '蒙奇',
  secName: 'D',
  thirdName: '路飛'
 },
 computed: {
  luFei_Name: function () {
   return this.firstName + this.secName + this.thirdName
  }
 }
})

// 將“路飛”改為“海軍王”
vm.thirdName = '海軍王'
// 打印路飛的全名
console.log(vm.luFei_Name)

但是:
有一天,路飛的逗逼爺爺卡普椅邓,一不小心發(fā)現(xiàn)可能把族譜搞錯(cuò)了柠逞,實(shí)際上,他們不是“D”之一族景馁,而是“H”一族板壮,也就是說,“蒙奇-D-路飛”可能要叫做“蒙奇-H-路飛”了
將最后一段代碼改為如下:
// 將“D”改為“H”
vm.secName = 'H'
// 打印路飛的全名
console.log(vm.luFei_Name)

methods不處理數(shù)據(jù)邏輯關(guān)系合住,只提供可調(diào)用的函數(shù)
相比于watch/computed绰精,methods不處理數(shù)據(jù)邏輯關(guān)系,只提供可調(diào)用的函數(shù)

new Vue({
 el: '#app',
 template: '<div id="app"><p>{{ say() }}</p></div>',
 methods: {
  say: function () {
   return '我要成為海賊王'
  }
 }
})

因此透葛,computed 在數(shù)據(jù)未發(fā)生變化時(shí)笨使,優(yōu)先讀取緩存。computed 計(jì)算屬性只有在相關(guān)的數(shù)據(jù)發(fā)生變化時(shí)才會改變要計(jì)算的屬性僚害,當(dāng)相關(guān)數(shù)據(jù)沒有變化時(shí)阱表,它會讀取緩存。而不必想 motheds方法 和 watch 方法是的每次都去執(zhí)行函數(shù)贡珊。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市涉馁,隨后出現(xiàn)的幾起案子门岔,更是在濱河造成了極大的恐慌,老刑警劉巖烤送,帶你破解...
    沈念sama閱讀 221,820評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件寒随,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)妻往,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,648評論 3 399
  • 文/潘曉璐 我一進(jìn)店門互艾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人讯泣,你說我怎么就攤上這事纫普。” “怎么了好渠?”我有些...
    開封第一講書人閱讀 168,324評論 0 360
  • 文/不壞的土叔 我叫張陵昨稼,是天一觀的道長。 經(jīng)常有香客問我拳锚,道長假栓,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,714評論 1 297
  • 正文 為了忘掉前任霍掺,我火速辦了婚禮匾荆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘杆烁。我一直安慰自己牙丽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,724評論 6 397
  • 文/花漫 我一把揭開白布连躏。 她就那樣靜靜地躺著剩岳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪入热。 梳的紋絲不亂的頭發(fā)上拍棕,一...
    開封第一講書人閱讀 52,328評論 1 310
  • 那天,我揣著相機(jī)與錄音勺良,去河邊找鬼绰播。 笑死,一個(gè)胖子當(dāng)著我的面吹牛尚困,可吹牛的內(nèi)容都是我干的蠢箩。 我是一名探鬼主播,決...
    沈念sama閱讀 40,897評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼事甜,長吁一口氣:“原來是場噩夢啊……” “哼谬泌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起逻谦,我...
    開封第一講書人閱讀 39,804評論 0 276
  • 序言:老撾萬榮一對情侶失蹤掌实,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后邦马,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體贱鼻,經(jīng)...
    沈念sama閱讀 46,345評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宴卖,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,431評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了邻悬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片症昏。...
    茶點(diǎn)故事閱讀 40,561評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖父丰,靈堂內(nèi)的尸體忽然破棺而出肝谭,到底是詐尸還是另有隱情,我是刑警寧澤础米,帶...
    沈念sama閱讀 36,238評論 5 350
  • 正文 年R本政府宣布分苇,位于F島的核電站葡缰,受9級特大地震影響钢拧,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜盈咳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,928評論 3 334
  • 文/蒙蒙 一蘑斧、第九天 我趴在偏房一處隱蔽的房頂上張望靖秩。 院中可真熱鬧,春花似錦竖瘾、人聲如沸沟突。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,417評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽惠拭。三九已至,卻和暖如春庸论,著一層夾襖步出監(jiān)牢的瞬間职辅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,528評論 1 272
  • 我被黑心中介騙來泰國打工聂示, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留域携,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,983評論 3 376
  • 正文 我出身青樓鱼喉,卻偏偏與公主長得像秀鞭,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子扛禽,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,573評論 2 359