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

Vue3?計(jì)算屬性的用法詳解

 更新時(shí)間:2022年07月07日 07:57:50   作者:ed。  
學(xué)過?vue2?的寶子們應(yīng)該都清楚,計(jì)算屬性這個(gè)東西在項(xiàng)目開發(fā)過程中使用的還是比較頻繁的,使用頻率相對(duì)來說比較高。本文就來為大家介紹一下Vue3中計(jì)算屬性的用法,需要的可以參考一下

上一篇博文說了 vue3 項(xiàng)目的 toRefs 函數(shù)和 toRef 函數(shù),今天就稍微總結(jié)一下 vue3 的計(jì)算屬性,其實(shí)學(xué)過 vue2 的寶子們應(yīng)該都清楚,計(jì)算屬性這個(gè)東西在項(xiàng)目開發(fā)過程中使用的還是比較頻繁的,使用頻率相對(duì)來說比較高,所以說咱今天稍微總結(jié)一下 vue3 項(xiàng)目中的計(jì)算屬性,下面開始。

computed 計(jì)算屬性說明

computed 表示計(jì)算屬性,通常的作用是用來進(jìn)行數(shù)據(jù)處理,方便在末班中簡化書寫。

比如日常在模板中我們渲染數(shù)據(jù)的時(shí)候一般是使用 {{ }} 來進(jìn)行展示數(shù)據(jù),但是有的時(shí)候嘞,獲取到的數(shù)據(jù)并不是我們想要的類型,我們可以在 {{ }} 中編寫表達(dá)式轉(zhuǎn)換成我們需要的類型,但是呢,這樣做簡單的還可以,如果相對(duì)復(fù)雜的格式在 {{ }} 中編寫的話就會(huì)造成模板代碼繁瑣,不易維護(hù)和閱讀,所以這并不是最好的編碼習(xí)慣,因此,vue3 也為我們提供了一些好的解決方案,計(jì)算屬性就是其中一種。

計(jì)算屬性可以幫我們將數(shù)據(jù)轉(zhuǎn)換成需要展示的數(shù)據(jù)格式,不必在模板中編寫大量的表達(dá)式進(jìn)行處理。

計(jì)算屬性使用

首先呢,使用 computed 需要引入。

import { computed } from 'vue'

引入這一個(gè)步驟是不可或缺的。

然后我們編寫一個(gè)案例,就是一個(gè)頁面有兩個(gè)輸入框,第一個(gè)輸入框的數(shù) 加上 第二個(gè)輸入框的數(shù),使用計(jì)算屬性在第三個(gè)輸入框求和。

<template>
  <div>
    <h1>computed 計(jì)算屬性</h1>
    <el-input v-model="num1" /> +
    <el-input v-model="num2" /> =
    <el-input v-model="num3" />
  </div>
</template>
<script>
  import { computed, ref } from 'vue'
  export default {
    setup() {
      const num1 = ref('')
      const num2 = ref('')
      const num3 = computed(() => {
        return Number(num1.value) + Number(num2.value)
      })
      return { num1, num2, num3 }
    }
  }
</script>
<style scoped>
  .el-input {
    width: 100px;
  }
</style>

保存刷新,輸如前兩個(gè)輸入框的值,會(huì)自動(dòng)計(jì)算和展示在第三個(gè)輸入框。

這樣就實(shí)現(xiàn)了最簡單的計(jì)算屬性。

計(jì)算屬性不是只可以寫一個(gè)的,可以寫任意多個(gè)計(jì)算屬性,怎么操作呢?看代碼:

<template>
  <div>
    <h1>computed 計(jì)算屬性</h1>
    <el-input v-model="num1" /> +
    <el-input v-model="num2" /> =
    <el-input v-model="num3" />
    <hr>
    <el-input v-model="num1" /> -
    <el-input v-model="num2" /> =
    <el-input v-model="num4" />
  </div>
</template>
<script>
  import { computed, reactive, toRefs } from 'vue'
  export default {
    setup() {
      const num1 = ''
      const num2 = ''
      const all = reactive({ num1, num2 })

      // 計(jì)算屬性求和
      const num3 = computed(() => {
        return Number(all.num1) + Number(all.num2)
      })

      // 計(jì)算屬性求差
      const num4 = computed(() => {
        return Number(all.num1) - Number(all.num2)
      })
      return { ...toRefs(all), num3, num4 }
    }
  }
</script>
<style scoped>
  .el-input {
    width: 100px;
  }
</style>

保存刷新,我們看到除了求和,還可以求差。

這樣的話,就實(shí)現(xiàn)了在一個(gè)頁面實(shí)現(xiàn)多個(gè)計(jì)算屬性的操作,完全不用寫在一個(gè)計(jì)算屬性里面進(jìn)行判斷處理,很靈活,當(dāng)然了,有三個(gè)可以寫三個(gè),有四個(gè)可以寫四個(gè)。

但是有一點(diǎn)需要注意!

如果我們直接修改計(jì)算屬性的值會(huì)報(bào)一個(gè)錯(cuò)誤!

比如我們有一個(gè)按鈕,點(diǎn)擊之后把 num4 修改為 10 。

      function btn() {
        console.log(num4)
        num4.value = 10
      }

我們可以看一下效果。

沒錯(cuò),他會(huì)有一個(gè)錯(cuò)誤,這個(gè)意思都懂,就是計(jì)算屬性是只讀的不允許修改。

為什么呢?

總結(jié): 如果傳遞給 computed 的是一個(gè)函數(shù),那么這就是一個(gè) getter 函數(shù),我們只能獲取它的值,而不能直接修改它。

那我需要修改計(jì)算屬性的值,我們需要怎么操作呢?其實(shí)很簡單,只需要傳進(jìn)去一個(gè)對(duì)象。

	  // 計(jì)算屬性求和
      const num3 = computed({
        get: () => {
          return Number(all.num1) + Number(all.num2)
        },
        set:(value) => {
          console.log(value)
          return all.num2 = Number(value) + 1
        }
      })

也就是說,計(jì)算屬性傳入一個(gè)對(duì)象, 包含get 和 set 函數(shù), 就能實(shí)現(xiàn)創(chuàng)建一個(gè)可以修改的計(jì)算屬性。

案例:

<template>
  <div>
    <h1>computed 計(jì)算屬性</h1>
    <el-input v-model="num1" /> +
    <el-input v-model="num2" /> =
    <el-input v-model="num3" />
    <br>
    <br>
    <el-button type="primary" @click="btn">修改計(jì)算屬性</el-button>
  </div>
</template>
<script>
  import { computed, reactive, toRefs } from 'vue'
  export default {
    setup() {
      const num1 = ''
      const num2 = ''
      const all = reactive({ num1, num2 })

      // 計(jì)算屬性求和
      const num3 = computed({
        get: () => {
          return Number(all.num1) + Number(all.num2)
        },
        set:(value) => {
          console.log(value)
          return all.num2 = Number(value) + 1
        }
      })

      function btn() {
        num3.value = '10'
      }

      return { ...toRefs(all), num3, btn }
    }
  }
</script>
<style scoped>
  .el-input {
    width: 100px;
  }
</style>

點(diǎn)擊按鈕,把 num2 改成輸入的數(shù)字 + 1,也就是11。

好的,這就實(shí)現(xiàn)了修改計(jì)算屬性。

總結(jié)

  • vue.3.0 中用于從vue 按需導(dǎo)入 computed 計(jì)算屬性。
  • 如果傳入的是一個(gè)getter 函數(shù), 會(huì)返回一個(gè)不允許修改的計(jì)算屬性。
  • 使用ref 創(chuàng)建一個(gè)響應(yīng)式對(duì)象, 在模板中使用不用自動(dòng)解套。 直接渲染使用。
  • 傳入一個(gè)對(duì)象, 包含get 和 set 函數(shù), 就可以創(chuàng)建一個(gè)可以修改的計(jì)算屬性。
  • 只可以獲取值,不允許修改值直接使用 computed 計(jì)算屬性使用箭頭函數(shù)。
  • 既可以獲取值, 也可以修改值, computed 計(jì)算屬性中傳入一個(gè)對(duì)象。 get 方法 和 set 方法。

注意

在 vue2 中,有一個(gè)叫做過濾器的家伙,從 vue3 開始,過濾器已經(jīng)被移除,且不再進(jìn)行支持。官方給的建議是用方法調(diào)用或計(jì)算屬性來替換它們。

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

相關(guān)文章

  • vue實(shí)現(xiàn)釘釘?shù)目记谌諝v

    vue實(shí)現(xiàn)釘釘?shù)目记谌諝v

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)釘釘?shù)目记谌諝v,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • 教你在Vue3中使用useStorage輕松實(shí)現(xiàn)localStorage功能

    教你在Vue3中使用useStorage輕松實(shí)現(xiàn)localStorage功能

    這篇文章主要給大家介紹了關(guān)于如何在Vue3中使用useStorage輕松實(shí)現(xiàn)localStorage功能的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-06-06
  • 淺析vue3項(xiàng)目中自定義指令的運(yùn)用

    淺析vue3項(xiàng)目中自定義指令的運(yùn)用

    自定義指令是一種在Vue應(yīng)用程序中擴(kuò)展HTML標(biāo)簽的能力,通過自定義指令,我們可以直接在模板中使用指令名,下面我們就來看看項(xiàng)目中具體如何使用自定義指令的吧
    2023-08-08
  • 解決element-ui的table表格控件表頭與內(nèi)容列不對(duì)齊問題

    解決element-ui的table表格控件表頭與內(nèi)容列不對(duì)齊問題

    這篇文章主要介紹了解決element-ui的table表格控件表頭與內(nèi)容列不對(duì)齊問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue使用urlEncode問題

    vue使用urlEncode問題

    這篇文章主要介紹了vue使用urlEncode問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue3動(dòng)態(tài)修改打包后的請(qǐng)求路徑的操作代碼

    vue3動(dòng)態(tài)修改打包后的請(qǐng)求路徑的操作代碼

    這篇文章主要介紹了vue3動(dòng)態(tài)修改打包后的請(qǐng)求路徑,需要我們創(chuàng)建一個(gè)靜態(tài)資源里的外部文件來實(shí)現(xiàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • vue?element-ui如何在el-tabs組件最右側(cè)添加按鈕

    vue?element-ui如何在el-tabs組件最右側(cè)添加按鈕

    這篇文章主要介紹了vue?element-ui如何在el-tabs組件最右側(cè)添加按鈕問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Vue使用Element實(shí)現(xiàn)增刪改查+打包的步驟

    Vue使用Element實(shí)現(xiàn)增刪改查+打包的步驟

    這篇文章主要介紹了Vue使用Element實(shí)現(xiàn)增刪改查+打包的步驟,幫助大家更好的理解和學(xué)習(xí)vue框架,感興趣的朋友可以了解下
    2020-11-11
  • vue 倒計(jì)時(shí)結(jié)束跳轉(zhuǎn)頁面實(shí)現(xiàn)代碼

    vue 倒計(jì)時(shí)結(jié)束跳轉(zhuǎn)頁面實(shí)現(xiàn)代碼

    在商場大家經(jīng)??吹酵\囀召M(fèi)倒計(jì)時(shí)支付頁面,今天小編通過本文給大家分享vue 倒計(jì)時(shí)結(jié)束跳轉(zhuǎn)頁面功能,感興趣的朋友一起看看吧
    2023-10-10
  • 淺談VUE uni-app 自定義組件

    淺談VUE uni-app 自定義組件

    這篇文章主要介紹了uni-app 的自定義組件,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-10-10

最新評(píng)論