vue中务唐,計(jì)算屬性 computed 和 watch 的區(qū)別

methods雳攘,watch和computed都是以函數(shù)為基礎(chǔ)的,但各自卻都不同枫笛;

1吨灭,methods

不存在緩存,執(zhí)行一次運(yùn)行一次刑巧,執(zhí)行n次喧兄,運(yùn)行n次

2,computed

使用場景:當(dāng)頁面中有某些數(shù)據(jù)依賴其他數(shù)據(jù)進(jìn)行變動(dòng)的時(shí)候海诲,可以使用計(jì)算屬性
計(jì)算屬性 computed 是基于data中數(shù)據(jù)進(jìn)行處理的繁莹,data數(shù)據(jù)變化,他也跟著變化
當(dāng)data中數(shù)據(jù)沒有發(fā)生改變時(shí)特幔,我們調(diào)用computed中函數(shù)n次咨演,只會(huì)進(jìn)行緩存(執(zhí)行一次)
每個(gè)計(jì)算屬性都包含兩個(gè)set、get 屬性

<div>{{get}} </div> //調(diào)用時(shí)候蚯斯,直接寫上函數(shù)名即可

computed: {
        get: function () { //這里不適合寫 get()薄风,語法規(guī)定
                return this.firstName + ' ' + this.lastName;// 必須要有return
       },
 }

2,watch

使用場景:數(shù)據(jù)變化時(shí)執(zhí)行異步或開銷較大的操作拍嵌,可以隨時(shí)修改狀態(tài)的變化
watch:類似于監(jiān)聽機(jī)制+事件機(jī)制遭赂。
在大部分情況下我們都會(huì)使用computed,但如果要在數(shù)據(jù)變化的同時(shí)進(jìn)行異步操作或者是比較大的開銷横辆,那么watch為最佳選擇撇他。watch為一個(gè)對(duì)象,鍵是需要觀察的表達(dá)式狈蚤,值是對(duì)應(yīng)回調(diào)函數(shù)困肩。值也可以是方法名,或者包含選項(xiàng)的對(duì)象脆侮。

// 這里直接用 v-model 來綁定锌畸,不需要添加 change 事件
<input type="text" v-model="nameValue" style="margin-top:15px" />  {{tip}}
        

  data() {
    return {
      nameValue: "",
      tip: ""
    };
  },
  methods: {
    checkName(value) {
      var that = this;
      setTimeout(() => {
        if (value == "admin") {
          that.tip = "用戶名已存在";
        } else {
          that.tip = "用戶名可以使用";
        }
      }, 2000);
    }
  },
  watch: {// 數(shù)據(jù)變化時(shí)執(zhí)行異步或開銷較大的操作
    nameValue(value) {
      this.checkName(value);
      this.tip = "正在驗(yàn)證......";
    }
  }

2,watch的兩種用法

注靖避,上面的watch方法是當(dāng)改變值時(shí)候潭枣,才會(huì)觸發(fā)監(jiān)聽事件,但是我們想剛進(jìn)入頁面時(shí)候幻捏,就觸發(fā)監(jiān)聽事件盆犁,就要用handler()方法

 data() {
    return {
        a: {
            b: {
                c: ' '
            }
        }
    };
  },

1,handler():當(dāng)頁面剛進(jìn)入時(shí)篡九,自動(dòng)綁定watch事件蚣抗,不需要進(jìn)行觸發(fā)

watch: {// 頁面加載時(shí),就自動(dòng)觸發(fā)此事件
  a :{
    handler(new){
       this.checkName(value);
       this.tip = "正在驗(yàn)證......";
    },
     immediate: true, // 代表在wacth里聲明了firstName這個(gè)方法之后立即先去執(zhí)行handler方法
     deep:true // 意味著開啟深度監(jiān)聽,對(duì)象 a 里面有任何數(shù)據(jù)變化都會(huì)觸發(fā)handler函數(shù)
  }
}

注:

  • immediate屬性:布爾值
    immediate:true:首次加載就監(jiān)聽數(shù)據(jù)變化
    immediate:false:只有發(fā)生改變才監(jiān)聽
  • deep:true翰铡;是開啟深層次的監(jiān)聽,即所有屬性都加上監(jiān)聽器讽坏,如果其中一個(gè)發(fā)生改變了就執(zhí)行handler函數(shù)锭魔。

2,第二種

watch: {
    'a.b.c' : function(){ // 第一種
        this.checkName(value);
        this.tip = "正在驗(yàn)證......";
    } 
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末路呜,一起剝皮案震驚了整個(gè)濱河市迷捧,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌胀葱,老刑警劉巖漠秋,帶你破解...
    沈念sama閱讀 211,348評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異抵屿,居然都是意外死亡庆锦,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門轧葛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來搂抒,“玉大人,你說我怎么就攤上這事尿扯∏缶В” “怎么了?”我有些...
    開封第一講書人閱讀 156,936評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵衷笋,是天一觀的道長芳杏。 經(jīng)常有香客問我,道長辟宗,這世上最難降的妖魔是什么爵赵? 我笑而不...
    開封第一講書人閱讀 56,427評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮慢蜓,結(jié)果婚禮上亚再,老公的妹妹穿的比我還像新娘。我一直安慰自己晨抡,他們只是感情好氛悬,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,467評(píng)論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著耘柱,像睡著了一般如捅。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上调煎,一...
    開封第一講書人閱讀 49,785評(píng)論 1 290
  • 那天镜遣,我揣著相機(jī)與錄音,去河邊找鬼士袄。 笑死悲关,一個(gè)胖子當(dāng)著我的面吹牛谎僻,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播寓辱,決...
    沈念sama閱讀 38,931評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼艘绍,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了秫筏?” 一聲冷哼從身側(cè)響起诱鞠,我...
    開封第一講書人閱讀 37,696評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎这敬,沒想到半個(gè)月后航夺,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,141評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡崔涂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,483評(píng)論 2 327
  • 正文 我和宋清朗相戀三年阳掐,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片堪伍。...
    茶點(diǎn)故事閱讀 38,625評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡锚烦,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出帝雇,到底是詐尸還是另有隱情涮俄,我是刑警寧澤,帶...
    沈念sama閱讀 34,291評(píng)論 4 329
  • 正文 年R本政府宣布尸闸,位于F島的核電站彻亲,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏吮廉。R本人自食惡果不足惜苞尝,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,892評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宦芦。 院中可真熱鬧宙址,春花似錦、人聲如沸调卑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽恬涧。三九已至注益,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間溯捆,已是汗流浹背丑搔。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人啤月。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓煮仇,卻偏偏與公主長得像,于是被迫代替她去往敵國和親顽冶。 傳聞我的和親對(duì)象是個(gè)殘疾皇子欺抗,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,492評(píng)論 2 348