Vue開發中計算屬性與方法調用之間的區別與聯系

文章目錄

    • 一 概述
    • 二 核心區別
    • 三 聯系
    • 四 使用原則

一 概述

在 Vue 中,計算屬性(computed) 和 方法(methods) 都可以用于處理數據邏輯,但它們的核心區別在于 緩存機制 和 觸發方式 。

計算屬性示例:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>demo</title>
</head><body><!-- 使用computed --><div id="app"><button v-on:click="a++">a+1</button><button v-on:click="b++">b+1</button><p>number + a = {{add1}}</p><p>number + b = {{add2}}</p></div><script src="https://unpkg.com/vue@3/dist/vue.global.js"></script><script>const vm = Vue.createApp({data() {return {a: 0,b: 0,number: 30};},computed: {add1: function() {console.log("This is add1 computed function: " +this.a);return this.a + this.number;},add2: function() {console.log("This is add2 computed function: " +this.b);return this.b + this.number;}}}).mount("#app");</script>
</body></html>

頁面加載時,控制臺打印結果如下:

This is add1 computed function: 0
This is add2 computed function: 0

連續點擊2次a+1按鈕,再點擊一次b+1按鈕,控制臺運行結果如下:
![運行結果(https://i-blog.csdnimg.cn/direct/290985ee437f4bab9bee11ff72251a02.png)
方法調用示例:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>demo</title>
</head><body><!-- 使用methods --><div id="app"><button v-on:click="a++">a+1</button><button v-on:click="b++">b+1</button><p>number + a = {{add1()}}</p><p>number + b = {{add2()}}</p></div><script src="https://unpkg.com/vue@3/dist/vue.global.js"></script><script>const vm = Vue.createApp({data() {return {a: 0,b: 0,number: 30};},methods: {add1: function() {console.log("This is add1 method:" + this.a);return this.a + this.number;},add2: function() {console.log("This is add2 method:" + this.b);return this.b + this.number;}}}).mount("#app");</script>
</body></html>

頁面加載時,控制臺打印結果如下:

This is add1 computed function: 0
This is add2 computed function: 0

連續點擊2次a+1按鈕,再點擊一次b+1按鈕,控制臺運行結果如下:
運行結果

二 核心區別

特性計算屬性(computed)方法(methods)
緩存機制基于依賴的響應式數據自動緩存,依賴不變時直接返回緩存值。無緩存,每次組件渲染時都會執行。
觸發時機僅當依賴的響應式數據變更時重新計算。每次渲染或調用時都會執行。
調用方式在模板中直接當作屬性使用(無需調用)。 計算屬性的調用不能使用括號,例如 add1、add2。必須顯式調用,需要加上括號,例如 add1()、add2()。
適用場景復雜邏輯、依賴其他數據且需緩存的場景(如過濾、計算衍生值)。事件處理、不依賴緩存的動態操作(如提交表單)。

三 聯系

共同點

  • 都可以處理數據邏輯,返回衍生值。
  • 都能訪問組件實例的 data、props 等屬性。

互補場景

  • 計算屬性適合 高開銷、依賴明確 的邏輯(如過濾列表、復雜計算)。
  • 方法適合事件驅動或無需緩存的操作(如表單提交、動態參數生成)。

四 使用原則

計算屬性相較于方法更加優化,但并不是什么情況下都可以使用計算屬性,在觸發事件時還是使用對應的方法。計算屬性一般在數據量比較大、比較耗時的情況下使用(例如搜索),只有虛擬DOM 與真實 DOM 不同的情況下才會執行 computed。如果你的業務實現不需要有緩存,計算屬性可以使用方法來代替。
優先使用計算屬性 :
當需要根據響應式數據動態生成值,且該值會被多次使用或計算成本較高時。
使用方法 :
當邏輯不依賴響應式數據,或需要顯式觸發(如按鈕點擊事件)。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/71854.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/71854.shtml
英文地址,請注明出處:http://en.pswp.cn/web/71854.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Unity】 HTFramework框架(六十一)Project窗口文件夾鎖定器

更新日期&#xff1a;2025年3月7日。 Github源碼&#xff1a;[點我獲取源碼] Gitee源碼&#xff1a;[點我獲取源碼] 索引 Project窗口文件夾鎖定器框架文件夾鎖定自定義文件夾鎖定限制條件 Project窗口文件夾鎖定器 在Project窗口中&#xff0c;文件夾鎖定器能夠為任何文件夾加…

C語言:6.20字符型數據練習題

編寫程序,輸人一行數字字符(用回車結束),每個數字字符 的前后都有空格。 把這一行中的數字轉換成一個整數。 例如,若輸入(<CR>代表 Enter鍵):2 4 8 3<CR>則輸出 整數:2483。 #include <stdio.h>int main() {char ch;int number 0;printf("請輸入一行…

【軟件工程】一篇入門UML建模圖(狀態圖、活動圖、構件圖、部署圖)

&#x1f308; 個人主頁&#xff1a;十二月的貓-CSDN博客 &#x1f525; 系列專欄&#xff1a; &#x1f3c0;軟件開發必練內功_十二月的貓的博客-CSDN博客 &#x1f4aa;&#x1f3fb; 十二月的寒冬阻擋不了春天的腳步&#xff0c;十二點的黑夜遮蔽不住黎明的曙光 目錄 1. 前…

【C語言】數組篇

目錄 引言一維數組數組的定義數組的初始化完全初始化部分初始化省略數組長度 數組元素的訪問 多維數組二維數組的定義二維數組的初始化完全初始化部分初始化省略第一維長度 二維數組元素的訪問 遍歷數組元素遍歷一維數組遍歷二維數組 數組作為函數參數一維數組作為函數參數二維…

OpenCV視頻解碼性能優化十連擊(實測幀率提升300%)

解密工業級視頻處理優化方案&#xff01;從硬件加速到多線程榨干CPU/GPU性能&#xff0c;附RTSP流調優參數與內存泄漏排查技巧。 &#x1f527; 優化前準備 環境檢測腳本 import cv2# 驗證硬件加速支持 print("CUDA支持:", cv2.cuda.getCudaEnabledDeviceCount() &…

基于編譯器特性淺析C++程序性能優化

最近在惡補計算機基礎知識&#xff0c;學到CSAPP第五章的內容&#xff0c;在這里總結并且展開一下C程序性能優化相關的內容。 衡量程序性能的方式 一般而言&#xff0c;程序的性能可以用CPE&#xff08;Cycles Per Element&#xff09;來衡量&#xff0c;其指的是處理每個元素…

transformer模型介紹——大語言模型 LLMBook 學習(二)

1. transformer模型 1.1 注意力機制 **注意力機制&#xff08;Attention Mechanism&#xff09;**在人工智能中的應用&#xff0c;實際上是對人類認知系統中的注意力機制的一種模擬。它主要模仿了人類在處理信息時的選擇性注意&#xff08;Selective Attention&#xff09;&a…

word甲烷一鍵下標

Sub 甲烷下標()甲烷下標 宏Selection.Find.ClearFormattingSelection.Find.Replacement.ClearFormattingWith Selection.Find.Text "CH4".Replacement.Text "CHguoshao4".Forward True.Wrap wdFindContinue.Format False.MatchCase False.MatchWhole…

Dify 本地部署教程

目錄 一、下載安裝包 二、修改配置 三、啟動容器 四、訪問 Dify 五、總結 本篇文章主要記錄 Dify 本地部署過程,有問題歡迎交流~ 一、下載安裝包 從 Github 倉庫下載最新穩定版軟件包,點擊下載~,當然也可以克隆倉庫或者從倉庫里直接下載zip源碼包。 目前最新版本是V…

2.1 掌握XML基礎知識

本文介紹了結構化、半結構化和非結構化數據的概念與特點。結構化數據以固定格式存儲于數據庫&#xff0c;便于查詢與管理&#xff0c;常用于金融等領域。半結構化數據如XML、JSON&#xff0c;具有一定的組織形式但模式不固定&#xff0c;適用于Web內容和日志文件。非結構化數據…

Android Studio 配置國內鏡像源

Android Studio版本號&#xff1a;2022.1.1 Patch 2 1、配置gradle國內鏡像&#xff0c;用騰訊云 鏡像源地址&#xff1a;https\://mirrors.cloud.tencent.com/gradle 2、配置Android SDK國內鏡像 地址&#xff1a;Index of /AndroidSDK/

超過 37000 臺 VMwareESXi 服務器可能受到持續攻擊威脅

近日&#xff0c;威脅監測平臺影子服務器基金會&#xff08;The Shadowserver Foundation&#xff09;發布報告&#xff0c;指出超 3.7 萬個互聯網暴露的威睿&#xff08;VMware&#xff09;ESXi 實例存在嚴重安全隱患&#xff0c;極易受到 CVE-2025-22224 漏洞的攻擊。該漏洞屬…

npm終端執行時報錯

終端npm執行時報錯下錯誤&#xff1a; 報錯了&#xff0c;就來百度&#xff0c;報錯的原因是 1、這個錯誤是因為 PowerShell 的執行策略&#xff08;Execution Policy&#xff09;限制了腳本的運行 2、默認情況下&#xff0c;Windows 系統可能會禁止運行未簽名的腳本&#x…

JVM類加載器面試題及原理

JVM只會運行二進制文件&#xff0c;類加載器的作用就是將字節碼文件加載到JVM中&#xff0c;從而讓Java程序能夠啟動起來。 1. 類加載器的種類 啟動類加載器&#xff08;BootStrap ClassLoader&#xff09;&#xff1a;加載JAVA_HOME/jre/lib目錄下的庫擴展類加載器&#xff…

C語言每日一練——day_3(快速上手C語言)

引言 針對初學者&#xff0c;每日練習幾個題&#xff0c;快速上手C語言。第三天。&#xff08;會連續更新&#xff09; 采用在線OJ的形式 什么是在線OJ&#xff1f; 在線判題系統&#xff08;英語&#xff1a;Online Judge&#xff0c;縮寫OJ&#xff09;是一種在編程競賽中用…

用Qt手搓AI助手,挑戰24小時開發DeepSeek Assistant!

一、項目需求分析與技術選型 DeepSeekAssistant是一款基于深度求索&#xff08;DeepSeek&#xff09;API的智能對話助手&#xff0c;核心需求包括&#xff1a; 用戶界面友好&#xff1a;支持多輪對話展示數據持久化&#xff1a;歷史記錄存儲與檢索異步網絡通信&#xff1a;AP…

Linux 環境變量快速上手指南

Linux 環境變量快速上手 1. 什么是環境變量 環境變量&#xff08;Environment Variables&#xff09;是操作系統中用于存儲配置信息的一種機制&#xff0c;可以在運行時被進程讀取和使用。常見環境變量示例&#xff1a; PATH: 存放可執行文件搜索路徑。HOME: 當前用戶的家目錄…

萬字技術指南STM32F103C8T6 + ESP8266-01 連接 OneNet 平臺 MQTT/HTTP

此博客為一份詳細的指南&#xff0c;涵蓋 STM32F103C8T6 通過 ESP8266-01 連接 OneNet 平臺&#xff0c;并使用 MQTT/HTTP 進行數據通信的完整流程。這份文檔包括&#xff1a; OneNet 平臺的介紹與功能概覽在 OneNet 上創建和配置設備的方法STM32CubeIDE 的開發環境搭建ESP826…

Go本地緩存設計與實現

本地緩存是一個項目中很常見的組件。在很多人的眼中就是一個簡單的key-value的map存儲即可實現&#xff0c;但實際上&#xff0c;設計一個本地緩存需要考慮的問題遠比你想象的多&#xff0c;比如說&#xff0c;本地緩存是將數據存儲在內存&#xff0c;若數據量激增突破了內存限…

深入解析 JavaScript 原型與原型鏈:從原理到應用

原型和原型鏈是 JavaScript 中實現對象繼承和屬性查找的核心機制。為了更深入地理解它們&#xff0c;我們需要從底層原理、實現機制以及實際應用等多個角度進行分析。 1. 原型&#xff08;Prototype&#xff09; 1.1 什么是原型&#xff1f; 每個 JavaScript 對象&#xff08…