日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

Vue(二) 计算属性

發布時間:2025/4/16 vue 70 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Vue(二) 计算属性 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

模板內的表達式常用于簡單的運算,當過長或邏輯復雜時,難以維護,計算屬性就是解決該問題的

什么是計算屬性

表達式如果過長,或邏輯更為復雜,就會變得臃腫甚至難以維護,比如:

<div>{{ text.split('.').reverse().join('.') }} </div>

該表達式包含 3 個操作,并不是很清晰,可以用計算屬性進行改寫:

<div id="app">{{ reverseText }} </div> <script>var app = new Vue({el: '#app',data: {text: '123,456'},computed: {reverseText: function () {//這里的 this 是當前的 Vue 實例return this.text.split(',').reverse().join(',');}}}) </script>

所有的計算屬性都以函數的形式寫在 Vue 實例內的 computed 選項內,最終返回計算結果。

計算屬性的用法

除了上例簡單的用法,計算屬性還可以依賴多個 Vue 實例的數據。只要其中任一數據變化,計算屬性就會重新執行,視圖也會更新。例如,下面的實例是在展示購物車內兩個包裹的總價。

<div id="app">{{ prices }} </div> <script>var app = new Vue({el: '#app',data: {package1: [{name: 'iphone xs max',price: 9999,count: 2},{name: 'ipad pro',price: 6666,count: 2}],package2: [{name: 'apple',price: 20,count: 20},{name: 'orange',price: 18,count: 20}]},computed: {prices: function () {var prices = 0;for(var i = 0; i < this.package1.length; i++) {prices += this.package1[i].price * this.package1[i].count;}for(var i = 0; i < this.package2.length; i++) {prices += this.package2[i].price * this.package2[i].count;}return prices;}}}) </script>

當 package1 和 package2 中的商品有任何變化時,比如購買數量變化或增刪商品時,計算屬性 prices 就會自動更新,視圖中的 prices 也會自動變化。

geter 和 setter

每一個計算屬性都包含一個 getter 和一個 setter,上面的兩個例子都是計算屬性的默認用法,只是利用了 getter 來讀取,在你需要時,也可以提供一個 setter 函數,當手動修改計算屬性的值時就會觸發 setter 函數,執行一些自定義操作,例如:

<div id="app">{{ fullName }} </div> <script>var app = new Vue({el: '#app',data: {firstName: 'Jack',lastName: 'Green'},computed: {fullName: {// getter, 用于讀取get: function () {return this.firstName + ' ' + this.lastName;},// setter,寫入時被觸發set: function (newValue) {var names = newValue.split(' ');this.firstName = names[0];this.lastName = names[names.length - 1];}}}}) </script>

當在瀏覽器的控制臺執行 app.fullName = 'John Doe'; 時,setter 就會被調用,數據 firstName 和 lastName 都會相對更新,視圖也會更新。

絕大多數情況下,我們只會用默認的 getter 方法來讀取一個計算屬性,在業務中很少用到 setter,因此在聲明一個計算屬性時,直接使用默認的方法即可,不必將 getter 和 setter 都聲明。

計算屬性除了上述簡單的文本插值外,還經常用于動態地設置元素的樣式名稱 class 和內聯樣式 style。當使用組件時,計算屬性也常用于動態傳遞 props。

計算屬性還有兩個很實用的小技巧:一個計算屬性可以依賴其他的計算屬性;二是計算屬性不僅可以依賴當前 Vue 實例的數據,還可以依賴其他實例的數據。

計算屬性緩存

在上一篇介紹指令和時間時,你可能發現調用 methods 里的方法也可以與計算屬性起到同樣的作用,比如本章第一個示例可以用 methods 改寫為:

<div id="app">{{ reverseText() }} </div> <script>var app = new Vue({<!-- 注意:這里的 reverseText 是方法,所以要帶() -->el: '#app',data: {text: '123,456'},methods: {reverseText: function () {//這里的 this 是當前的 Vue 實例return this.text.split(',').reverse().join(',');}}}) </script>

沒有使用計算屬性,在 methods 里定義了一個方法實現了相同的效果,甚至該方法還可以接受參數,使用起來更靈活。那為什么還需要計算屬性呢?原因就是計算屬性是基于它的依賴緩存的,一個計算屬性所依賴的的數據發生變化時,它才會重新取值,所以 text 只要不改變,計算屬性也就不更新,例如:

computed: {now: function() {return Date.now();} }

這里的 Dtae.now() 不是響應式依賴,所以計算屬性 now 不會更新。但是 methods 則不同,只要重新渲染,它就會被調用,因此函數也會被執行。

使用計算屬性還是 methods 取決于你是否需要緩存,當遍歷大數組和大量計算時,應當使用計算屬性,除非你不希望得到緩存。

轉載于:https://www.cnblogs.com/kindleheart/p/9983637.html

總結

以上是生活随笔為你收集整理的Vue(二) 计算属性的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。