欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2018年04月23日 09:18:17   作者:前端小智  
這篇文章主要介紹了詳解vue 計(jì)算屬性與方法跟偵聽器區(qū)別(面試考點(diǎn)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

計(jì)算屬性

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

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

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

所以,對于任何復(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é)果:

王小智

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

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

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

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

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

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


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

結(jié)果:

王小智

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

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

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

計(jì)算屬性 vs 偵聽屬性

你可能已經(jī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é)果:

王小智

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

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

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • VUE3.2項(xiàng)目使用Echarts5.4詳細(xì)步驟總結(jié)

    VUE3.2項(xiàng)目使用Echarts5.4詳細(xì)步驟總結(jié)

    Vue3.2是一款非常流行的JavaScript框架,它讓在前端領(lǐng)域開發(fā)變得更加的便捷,下面這篇文章主要給大家介紹了關(guān)于VUE3.2項(xiàng)目使用Echarts5.4的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • vue實(shí)現(xiàn)類似淘寶商品評價(jià)頁面星級評價(jià)及上傳多張圖片功能

    vue實(shí)現(xiàn)類似淘寶商品評價(jià)頁面星級評價(jià)及上傳多張圖片功能

    最近在寫一個(gè)關(guān)于vue的商城項(xiàng)目,然后集成在移動(dòng)端中,開發(fā)需求中有一界面,類似淘寶商城評價(jià)界面!接下來通過本文給大家分享vue實(shí)現(xiàn)類似淘寶商品評價(jià)頁面星級評價(jià)及上傳多張圖片功能,需要的朋友參考下吧
    2018-10-10
  • 詳解Vue組件實(shí)現(xiàn)tips的總結(jié)

    詳解Vue組件實(shí)現(xiàn)tips的總結(jié)

    這篇文章主要介紹了詳解Vue組件實(shí)現(xiàn)tips的總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11
  • vue 公共列表選擇組件,引用Vant-UI的樣式方式

    vue 公共列表選擇組件,引用Vant-UI的樣式方式

    這篇文章主要介紹了vue 公共列表選擇組件,引用Vant-UI的樣式方式,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 基于Vue3+TypeScript實(shí)現(xiàn)圖片預(yù)覽組件

    基于Vue3+TypeScript實(shí)現(xiàn)圖片預(yù)覽組件

    在現(xiàn)代的 Web 應(yīng)用中,圖片預(yù)覽是一個(gè)常見的需求,本文將介紹如何使用 Vue3 和 TypeScript 開發(fā)一個(gè)圖片預(yù)覽組件,支持展示單張或多張圖片,并提供了豐富的配置選項(xiàng),需要的朋友可以參考下
    2024-04-04
  • vue 計(jì)時(shí)器組件的實(shí)現(xiàn)代碼

    vue 計(jì)時(shí)器組件的實(shí)現(xiàn)代碼

    本篇文章主要介紹了vue 計(jì)時(shí)器組件的實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • vue.js綁定事件監(jiān)聽器示例【基于v-on事件綁定】

    vue.js綁定事件監(jiān)聽器示例【基于v-on事件綁定】

    這篇文章主要介紹了vue.js綁定事件監(jiān)聽器的方法,結(jié)合實(shí)例形式分析了vue.js基于v-on事件綁定響應(yīng)鼠標(biāo)點(diǎn)擊相關(guān)操作技巧,需要的朋友可以參考下
    2018-07-07
  • vue3:setup的兩個(gè)注意點(diǎn)詳解

    vue3:setup的兩個(gè)注意點(diǎn)詳解

    這篇文章主要介紹了vue3.0中setup的兩個(gè)注意點(diǎn),本文通過兩種用法給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-10-10
  • vue項(xiàng)目中$t()的意思是什么

    vue項(xiàng)目中$t()的意思是什么

    這篇文章主要介紹了vue項(xiàng)目中$t()的意思是什么,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 詳解從Vue.js源碼看異步更新DOM策略及nextTick

    詳解從Vue.js源碼看異步更新DOM策略及nextTick

    本篇文章主要介紹了從Vue.js源碼看異步更新DOM策略及nextTick,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一
    2017-10-10

最新評論