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

vue計(jì)算屬性及函數(shù)的選擇

 更新時(shí)間:2022年05月08日 16:57:07   作者:??劉溜溜????  
這篇文章主要介紹了vue計(jì)算屬性及函數(shù)的選擇,文章圍繞主題的相關(guān)資料展開詳細(xì)介紹,需要的小伙伴可以參考一下

一、計(jì)算屬性

使用場(chǎng)景

從已有的數(shù)據(jù)A中計(jì)算等到的新的數(shù)據(jù)B,使用計(jì)算屬性。

如果一個(gè)結(jié)果需要依賴data中的數(shù)據(jù),但是需要經(jīng)過(guò)一些邏輯處理,才能得到你想要的數(shù)據(jù)。此時(shí)就可以使用計(jì)算屬性。

定義格式

在vue實(shí)例中,補(bǔ)充computed配置項(xiàng)

普通寫法

{
    data(){},
    methods: {}
    // 聲明計(jì)算屬性
    computed: {
        //屬性名字(計(jì)算屬性名稱)
        //屬性的值(計(jì)算屬性處理函數(shù))
        計(jì)算屬性名1 () {
            // 對(duì)依賴的數(shù)據(jù)進(jìn)行處理,且進(jìn)行return
            return
        },
        計(jì)算屬性名2 () {
            // 對(duì)依賴的數(shù)據(jù)進(jìn)行處理,且進(jìn)行return
            return
        }
    }
}

computed是vue的配置選項(xiàng),它的值是一個(gè)對(duì)象,其中可定義多個(gè)計(jì)算屬性,每個(gè)計(jì)算屬性就是一個(gè)函數(shù)。

  • 屬性名稱: 計(jì)算屬性的名稱
  • 屬性的值:計(jì)算屬性的素材函數(shù)
    • 對(duì)需要依賴的數(shù)據(jù),進(jìn)行邏輯上的處理
    • 處理完畢后,需要return出去,返回的值就是計(jì)算屬性的值

使用格式

在兩個(gè)地方使用:

  • 模板
    • 用插值表達(dá)式 {{計(jì)算屬性名}}
    • 用其它指令
  • 在實(shí)例內(nèi)
    • this.計(jì)算屬性名

示例 —— 數(shù)組求和

<template>
  <div id="app">
    <p>求和:{{ sum1 }}</p>
  </div>
</template>

<script>
export default {
  data () {
    return {
      arr: [1,2,3,4]
    }
  },
  computed: {
    sum1(){
      // 對(duì)依賴的數(shù)據(jù)進(jìn)行處理,且進(jìn)行return
      return this.arr.reduce((sum, item)=>sum + item, 0)
    }
  }
}
</script>

在模板中使用計(jì)算屬性,和使用data的方式是一樣的。

雖然在計(jì)算屬性中聲明的是函數(shù),但是在模板是使用,當(dāng)做的數(shù)據(jù)來(lái)使用。不需要加括號(hào)。

小結(jié):

  • 什么時(shí)間用:需要對(duì)數(shù)據(jù)進(jìn)行復(fù)雜的邏輯加工,產(chǎn)生新的數(shù)據(jù)時(shí)。
  • 定義: 就是一個(gè)特殊的配置項(xiàng)computed。其中有多個(gè)函數(shù)。
  • 使用:計(jì)算屬性的使用方式與data中的數(shù)據(jù)項(xiàng)一致;
  • 計(jì)算屬性-計(jì)算:這個(gè)值是對(duì)原數(shù)據(jù)進(jìn)行計(jì)算之后得到的新的數(shù)據(jù)
  • 計(jì)算屬性-屬性:它的使用方法與原數(shù)據(jù)一樣。this.計(jì)算屬性名,{{計(jì)算屬性名}}
  • 執(zhí)行的時(shí)機(jī): 如果計(jì)算屬性中依賴的數(shù)據(jù)項(xiàng)變化時(shí),它會(huì)自動(dòng)調(diào)用。

computed有緩存

示例:

<template>
  <div id="app">
    <p>求和:{{ sum1 }}</p>
    <p>求和:{{ sum1 }}</p>
    <p>求和:{{ sum1 }}</p>
  </div>
</template>

<script>
export default {
  data () {
    return {
      arr: [1,2,3,4]
    }
  },
  computed: {
    sum1(){
      // 求arr的和,并返回
      // 如果arr變化了,計(jì)算屬性會(huì)重新計(jì)算
      console.log('計(jì)算屬性被調(diào)用了')
      return this.arr.reduce((sum, item)=>sum + item, 0)
    }
  }
}
</script>

結(jié)果:

  • 從上面的示例中可以看到,計(jì)算屬性在模板中被調(diào)用了三次,但控制臺(tái)只打印了一次,這是因?yàn)橛?jì)算屬性執(zhí)行前會(huì)先從緩存中查找有沒有這個(gè)數(shù)據(jù),如果有就不會(huì)執(zhí)行。
  • 計(jì)算屬性的執(zhí)行機(jī)制就像我們查字典一樣
    • 如果要計(jì)算的數(shù)據(jù)在緩存中能找到,就不會(huì)再執(zhí)行函數(shù),而是直接拿取數(shù)據(jù)。

二、總結(jié)

當(dāng)我們?cè)谀0逯衼?lái)顯示一份經(jīng)過(guò)對(duì)數(shù)據(jù)項(xiàng)進(jìn)行復(fù)雜計(jì)算之后的結(jié)果時(shí),我們有兩種解決方案:

  • 計(jì)算屬性
  • 函數(shù)

如何選擇:

  • methods定義函數(shù),如果在模板中使用,每使用一次,就相當(dāng)于調(diào)用了一次,處理邏輯會(huì)重新執(zhí)行。
  • computed定義計(jì)算屬性,如果在模板中使用,使用多次,但是如果依賴的數(shù)據(jù)不發(fā)生改變,計(jì)算屬性對(duì)應(yīng)的函數(shù)不會(huì)重新執(zhí)行。
    • 計(jì)算屬性會(huì)做緩存,提高渲染的性能。

到此這篇關(guān)于vue計(jì)算屬性及函數(shù)的選擇的文章就介紹到這了,更多相關(guān)vue計(jì)算屬性內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vuejs第八篇之Vuejs組件的定義實(shí)例解析

    Vuejs第八篇之Vuejs組件的定義實(shí)例解析

    這篇文章主要介紹了Vuejs第八篇之Vuejs組件的定義實(shí)例解析的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-09-09
  • vue實(shí)現(xiàn)無(wú)縫輪播效果(跑馬燈)

    vue實(shí)現(xiàn)無(wú)縫輪播效果(跑馬燈)

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)無(wú)縫輪播效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • vue截取視頻第一幀的圖片問(wèn)題

    vue截取視頻第一幀的圖片問(wèn)題

    這篇文章主要介紹了vue截取視頻第一幀的圖片問(wèn)題,基本就是用cavas進(jìn)行繪制,解決一下跨域問(wèn)題,截視頻第一幀,然后根據(jù)視頻原本的寬高進(jìn)行繪制,最后轉(zhuǎn)一下圖片格式即可,需要的朋友可以參考下
    2022-11-11
  • Vue利用computed配合watch實(shí)現(xiàn)監(jiān)聽多個(gè)屬性的變化

    Vue利用computed配合watch實(shí)現(xiàn)監(jiān)聽多個(gè)屬性的變化

    這篇文章主要給大家介紹了在Vue中巧用computed配合watch實(shí)現(xiàn)監(jiān)聽多個(gè)屬性的變化的方法,文中有詳細(xì)的代碼示例供大家參考,具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-10-10
  • 基于Vue實(shí)現(xiàn)圖書管理功能

    基于Vue實(shí)現(xiàn)圖書管理功能

    這篇文章主要為大家詳細(xì)介紹了基于Vue實(shí)現(xiàn)圖書管理功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • 淺談Vue-cli 命令行工具分析

    淺談Vue-cli 命令行工具分析

    本篇文章主要介紹了淺談Vue-cli 命令行工具分析,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-11-11
  • Vue中使用create-keyframe-animation與動(dòng)畫鉤子完成復(fù)雜動(dòng)畫

    Vue中使用create-keyframe-animation與動(dòng)畫鉤子完成復(fù)雜動(dòng)畫

    這篇文章主要介紹了Vue中使用create-keyframe-animation與動(dòng)畫鉤子完成復(fù)雜動(dòng)畫,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-04-04
  • Vue.js中輕松解決v-for執(zhí)行出錯(cuò)的三個(gè)方案

    Vue.js中輕松解決v-for執(zhí)行出錯(cuò)的三個(gè)方案

    v-for標(biāo)簽可以用來(lái)遍歷數(shù)組,將數(shù)組的每一個(gè)值綁定到相應(yīng)的視圖元素中去,下面這篇文章主要給大家介紹了關(guān)于在Vue.js中輕松解決v-for執(zhí)行出錯(cuò)的三個(gè)方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-06-06
  • Vue2.x通用編輯組件的封裝及應(yīng)用詳解

    Vue2.x通用編輯組件的封裝及應(yīng)用詳解

    這篇文章主要為大家詳細(xì)介紹了Vue2.x通用編輯組件的封裝及應(yīng)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • Vue?Mock.js介紹和使用與首頁(yè)導(dǎo)航欄左側(cè)菜單搭建過(guò)程

    Vue?Mock.js介紹和使用與首頁(yè)導(dǎo)航欄左側(cè)菜單搭建過(guò)程

    Mock.js是一個(gè)模擬數(shù)據(jù)的生成器,用來(lái)幫助前端調(diào)試開發(fā)、進(jìn)行前后端的原型分離以及用來(lái)提高自動(dòng)化測(cè)試效率,這篇文章主要介紹了Vue?Mock.js介紹和使用與首頁(yè)導(dǎo)航欄左側(cè)菜單搭建,需要的朋友可以參考下
    2023-09-09

最新評(píng)論