欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

詳解vue計(jì)算屬性與方法跟偵聽(tīng)器區(qū)別(面試考點(diǎn))

計(jì)算屬性

創(chuàng)新互聯(lián)專(zhuān)業(yè)為企業(yè)提供費(fèi)縣網(wǎng)站建設(shè)、費(fèi)縣做網(wǎng)站、費(fèi)縣網(wǎng)站設(shè)計(jì)、費(fèi)縣網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、費(fèi)縣企業(yè)網(wǎng)站模板建站服務(wù),十余年費(fèi)縣做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

模板內(nèi)的表達(dá)式非常便利,但是設(shè)計(jì)它們的初衷是用于簡(jiǎn)單運(yùn)算的。在模板中放入太多的邏輯會(huì)讓模板過(guò)重且難以維護(hù)。例如:

<div id="example">
 {{ message.split('').reverse().join('') }}
</div>

在這個(gè)地方,模板不再是簡(jiǎn)單的聲明式邏輯。你必須看一段時(shí)間才能意識(shí)到,這里是想要顯示變量 message 的翻轉(zhuǎn)字符串。當(dāng)你想要在模板中多次引用此處的翻轉(zhuǎn)字符串時(shí),就會(huì)更加難以處理。

所以,對(duì)于任何復(fù)雜邏輯,你都應(yīng)當(dāng)使用計(jì)算屬性。

基礎(chǔ)例子

<div id="app">
 {{fullName}}
</div>
  
  
var vm = new Vue({
 el: '#app',
 data: {
  firstName: "王",
  lastName: "小智",
  age: 28
 },
 // 計(jì)算屬性
 computed: {
   fullName: function () {
     console.log("計(jì)算了一次")
     return this.firstName + " " + this.lastName
   }
 }
})

結(jié)果:

王小智

然后我們通過(guò)瀏覽器改變age屬性的值,讓頁(yè)面重新渲染:

詳解vue 計(jì)算屬性與方法跟偵聽(tīng)器區(qū)別(面試考點(diǎn))

大家可以看到,我們改變了age值計(jì)算屬性的方法沒(méi)有被調(diào)用,那如果計(jì)算屬性的值發(fā)生了改變,如lastName或者firstName改變,打印結(jié)果又會(huì)怎么樣呢?

詳解vue 計(jì)算屬性與方法跟偵聽(tīng)器區(qū)別(面試考點(diǎn))

大家可以看到,當(dāng)他依賴(lài)的發(fā)生變化的時(shí)候,計(jì)算屬性會(huì)重新計(jì)算一次。

計(jì)算屬性緩存 vs 方法

你可能已經(jīng)注意到我們可以通過(guò)在表達(dá)式中調(diào)用方法來(lái)達(dá)到同樣的效果:

<p>Reversed message: "{{ fullName() }}"</p>


// 在組件中
methods: {
 fullName: function () {
  console.log("計(jì)算了一次")
  return this.firstName + " " + this.lastName;
 }
}

結(jié)果:

王小智

同樣參照上面,我們通過(guò)瀏覽器改變age屬性的值,讓頁(yè)面重新渲染:

詳解vue 計(jì)算屬性與方法跟偵聽(tīng)器區(qū)別(面試考點(diǎn))

可以看出,我們頁(yè)面只要重新渲染,方法都會(huì)執(zhí)行一次,而計(jì)算屬性只有在它的相關(guān)依賴(lài)發(fā)生改變時(shí)才會(huì)重新求值。

我們?yōu)槭裁葱枰彺??假設(shè)我們有一個(gè)性能開(kāi)銷(xiāo)比較大的的計(jì)算屬性 A,它需要遍歷一個(gè)巨大的數(shù)組并做大量的計(jì)算。然后我們可能有其他的計(jì)算屬性依賴(lài)于A 。如果沒(méi)有緩存,我們將不可避免的多次執(zhí)行 A 的 getter!如果你不希望有緩存,請(qǐng)用方法來(lái)替代。

計(jì)算屬性 vs 偵聽(tīng)屬性

你可能已經(jīng)注意到我們還可以通過(guò)偵聽(tīng)屬性達(dá)到同樣的效果:

var vm = new Vue({
 el: '#app',
 data: {
  firstName: "王",
  lastName: "小智",
  age: 28,
  fullName
 },
 // 計(jì)算屬性
 watch: {
   firstName: function () {
    console.log("計(jì)算了一次");
    this.fullNmae = this.firstName + this.lastName;
   },
   lastName: function () {
    console.log("計(jì)算了一次")
    this.fullNmae = this.firstName + this.lastName;
   }
 }
})

結(jié)果:

王小智

同樣參照上面,我們通過(guò)瀏覽器改變age屬性的值,讓頁(yè)面重新渲染:

詳解vue 計(jì)算屬性與方法跟偵聽(tīng)器區(qū)別(面試考點(diǎn))

大家可以看到,和fullname不相關(guān)的改變,fullName沒(méi)有變化,跟計(jì)算屬性類(lèi)似,會(huì)有緩存,只有在它的相關(guān)依賴(lài)發(fā)生改變時(shí)才會(huì)重新求值,將它與計(jì)算屬性的版本進(jìn)行比較,好得多了,不是嗎?

當(dāng)你有一些數(shù)據(jù)需要隨著其它數(shù)據(jù)變動(dòng)而變動(dòng)時(shí),你很容易濫用 watch——特別是如果你之前使用過(guò)
AngularJS。然而,通常更好的做法是使用計(jì)算屬性而不是命令式的 watch 回調(diào)。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

網(wǎng)頁(yè)標(biāo)題:詳解vue計(jì)算屬性與方法跟偵聽(tīng)器區(qū)別(面試考點(diǎn))
網(wǎng)址分享:http://chinadenli.net/article18/ppcpdp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、品牌網(wǎng)站制作企業(yè)網(wǎng)站制作微信小程序、網(wǎng)站策劃品牌網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

營(yíng)銷(xiāo)型網(wǎng)站建設(shè)
91偷拍裸体一区二区三区| 日本办公室三级在线观看| 亚洲高清欧美中文字幕| 尤物久久91欧美人禽亚洲| 亚洲综合色婷婷七月丁香| 久久永久免费一区二区| 欧美一区二区口爆吞精| 国内真实露脸偷拍视频| 美日韩一区二区精品系列| 色涩一区二区三区四区| 高潮少妇高潮久久精品99| 91人妻人人做人碰人人九色| 亚洲精品av少妇在线观看| 精品久久久一区二区三| 国产一区二区久久综合| 天堂热东京热男人天堂| 亚洲熟女精品一区二区成人| 91欧美亚洲视频在线| 一区二区日韩欧美精品| 日韩欧美国产精品自拍| 大香蕉伊人精品在线观看| 久久精品色妇熟妇丰满人妻91 | 欧洲日本亚洲一区二区| 免费在线播放不卡视频| 中文字幕不卡欧美在线| 日本国产欧美精品视频| 亚洲综合天堂一二三区| 成年女人下边潮喷毛片免费| 日韩免费av一区二区三区| 日韩女优精品一区二区三区| 麻豆91成人国产在线观看| 国产精品第一香蕉视频| 欧美日韩国产午夜福利| 色一情一乱一区二区三区码| 欧美老太太性生活大片| 中文字幕乱码亚洲三区| 日韩精品综合免费视频| 欧美日韩在线视频一区| 久久精品亚洲精品国产欧美| 白白操白白在线免费观看| 日本99精品在线观看|