第三課 計(jì)算屬性

3.1 什么是計(jì)算屬性

我們己經(jīng)可以搭建出一個(gè)簡(jiǎn)單的 Vue 應(yīng)用掌腰, 在模板中雙向綁定一些數(shù)據(jù)或表達(dá)式了。 但是表達(dá)式如果過長(zhǎng)张吉, 或邏輯更為復(fù)雜時(shí)齿梁, 就會(huì)變得雕腫甚至難以閱讀和維護(hù)

<div>
    {{ text.split ( ’,’ ) ?reverse () . join (’,’)}}
</div>

這里的表達(dá)式包含 3 個(gè)操作, 并不是很清晰肮蛹, 所以在遇到復(fù)雜的邏輯時(shí)應(yīng)該使用 計(jì)算屬性
所有的計(jì)算屬性都以函數(shù)的形式寫在 Vue 實(shí)例內(nèi)的computed選項(xiàng)內(nèi)勺择, 最終返回計(jì)算后的結(jié)果。

3.2 計(jì)算屬性用法

在一個(gè)計(jì)算屬性里可以完成各種復(fù)雜的邏輯省核, 包括運(yùn)算、 函數(shù)調(diào)用等昆码, 只要最終返回一個(gè)結(jié)果就可以气忠。 除了上例簡(jiǎn)單的用法,計(jì)算屬性還可以依賴多個(gè) Vue 實(shí)例的數(shù)據(jù)赋咽, 只要其中任一數(shù)據(jù)變化旧噪, 計(jì)算屬性就會(huì)重新執(zhí)行, 視圖也會(huì)更新

實(shí)例 :展示兩個(gè)購物車的物品總價(jià)
代碼:https://gist.github.com/huahua029/4ecae467853dad727a792fa3144b754c

getter和setter

每一個(gè)計(jì)算屬性都包含-個(gè) getter 和一個(gè) setter脓匿, 我們上面的兩個(gè)示例都是計(jì)算屬性的默認(rèn)用法 淘钟, 只是利用了 getter來讀取。 在你需要時(shí)亦镶, 也可以提供一個(gè) setter 函數(shù) 日月, 當(dāng)手動(dòng)修改計(jì)算屬性的值就像修改一個(gè)普通數(shù)據(jù)那樣時(shí), 就會(huì)觸發(fā) setter函數(shù)缤骨, 執(zhí)行一些自定義的操作計(jì)算屬性除了上述簡(jiǎn)單的文本插值外爱咬, 還經(jīng)常用于動(dòng)態(tài)地設(shè)置元素的樣式名稱 class 和內(nèi)聯(lián)樣式 style,

小技巧: 計(jì)算屬性還有兩個(gè)很實(shí)用的小技巧容易被忽略:
一、是計(jì)算屬性可以依賴其他計(jì)算屬性:
二绊起、是計(jì)算屬性不僅可以依賴當(dāng)前 Vue 實(shí)例的數(shù)據(jù)精拟, 還可以依賴其他實(shí)例的數(shù)據(jù)

3.3計(jì)算屬性緩存

調(diào)用 methods 里的方法也可以與計(jì)算屬性起到同樣的作用

頁面中的方法: 如果是調(diào)用方法, 只要頁面重新渲染虱歪。 方法就會(huì)重新執(zhí)行蜂绎, 不需要渲染, 則不需要重新執(zhí)行
計(jì)算屬性: 不管渲染不渲染笋鄙, 只要計(jì)算屬性依賴的數(shù)據(jù)未發(fā)生變化师枣, 就永遠(yuǎn)不變

結(jié)論: 沒有使用計(jì)算屬性, 在 methods 里定義了一個(gè)方法實(shí)現(xiàn)了相同的效果萧落, 甚至該方法還可以接受參數(shù)践美, 使用起來更靈活洗贰。 既然使用 methods 就可以實(shí)現(xiàn), 那么為什么還需要計(jì)算屬性呢陨倡? 原因就是

計(jì)算屬性是基于它的依賴緩存的敛滋。 一個(gè)計(jì)算屬性所依賴的數(shù)據(jù)發(fā)生變化時(shí), 它才會(huì)重新取值兴革, 所以text 只要不改變杂曲, 計(jì)算屬性也就不更新
何時(shí)使用: -----------使用計(jì)算屬性還是 methods 取決于你是否需要緩存庶艾, 當(dāng)遍歷大數(shù)組和做大量計(jì)算時(shí), 應(yīng)當(dāng)使用計(jì)算屬性落竹, 除非你不希望得到緩存。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末货抄,一起剝皮案震驚了整個(gè)濱河市述召,隨后出現(xiàn)的幾起案子怪与,更是在濱河造成了極大的恐慌耘斩,老刑警劉巖荚虚,帶你破解...
    沈念sama閱讀 211,123評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件梯澜,死亡現(xiàn)場(chǎng)離奇詭異渴析,居然都是意外死亡腊徙,警方通過查閱死者的電腦和手機(jī)简十,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來撬腾,“玉大人,你說我怎么就攤上這事恢恼∶裆担” “怎么了?”我有些...
    開封第一講書人閱讀 156,723評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵场斑,是天一觀的道長(zhǎng)漓踢。 經(jīng)常有香客問我,道長(zhǎng)漏隐,這世上最難降的妖魔是什么喧半? 我笑而不...
    開封第一講書人閱讀 56,357評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮青责,結(jié)果婚禮上挺据,老公的妹妹穿的比我還像新娘。我一直安慰自己脖隶,他們只是感情好扁耐,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著产阱,像睡著了一般婉称。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上构蹬,一...
    開封第一講書人閱讀 49,760評(píng)論 1 289
  • 那天王暗,我揣著相機(jī)與錄音,去河邊找鬼庄敛。 笑死俗壹,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的铐姚。 我是一名探鬼主播策肝,決...
    沈念sama閱讀 38,904評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼隐绵!你這毒婦竟也來了之众?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤依许,失蹤者是張志新(化名)和其女友劉穎棺禾,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體峭跳,經(jīng)...
    沈念sama閱讀 44,118評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡膘婶,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評(píng)論 2 325
  • 正文 我和宋清朗相戀三年缺前,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片悬襟。...
    茶點(diǎn)故事閱讀 38,599評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡衅码,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出脊岳,到底是詐尸還是另有隱情逝段,我是刑警寧澤,帶...
    沈念sama閱讀 34,264評(píng)論 4 328
  • 正文 年R本政府宣布割捅,位于F島的核電站奶躯,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏亿驾。R本人自食惡果不足惜嘹黔,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望莫瞬。 院中可真熱鬧儡蔓,春花似錦、人聲如沸乏悄。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽檩小。三九已至开呐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間规求,已是汗流浹背筐付。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評(píng)論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留阻肿,地道東北人瓦戚。 一個(gè)月前我還...
    沈念sama閱讀 46,286評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像丛塌,于是被迫代替她去往敵國和親较解。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,090評(píng)論 1 32
  • 1.ios高性能編程 (1).內(nèi)層 最小的內(nèi)層平均值和峰值(2).耗電量 高效的算法和數(shù)據(jù)結(jié)構(gòu)(3).初始化時(shí)...
    歐辰_OSR閱讀 29,334評(píng)論 8 265
  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容赴邻,還有我對(duì)于 Vue 1.0 印象不深的內(nèi)容印衔。關(guān)于...
    云之外閱讀 5,046評(píng)論 0 29
  • 1.安裝 可以簡(jiǎn)單地在頁面引入Vue.js作為獨(dú)立版本,Vue即被注冊(cè)為全局變量姥敛,可以在頁面使用了奸焙。 如果希望搭建...
    Awey閱讀 10,999評(píng)論 4 129
  • 女兒出生了与帆,媽媽過來幫忙照顧了赌,因此現(xiàn)在每天下班時(shí)間,老婆與媽媽都會(huì)問下班了嗎玄糟?有時(shí)候她們會(huì)等我回去了再吃飯勿她,有時(shí)候...
    mcfs閱讀 270評(píng)論 0 0