Vue 3 中的 setup 函數是如何工作的?

Vue 3 中的?setup?函數是一個新的組件選項,用于使用組合式 API 定義組件的邏輯。這個函數的引入是為了解決 Vue 2 中隨著組件復雜度的增長,選項式的 API 可能導致代碼難以維護和理解的問題。通過?setup?函數,開發者可以更加靈活地組織和共享代碼邏輯,提高代碼的可讀性和可維護性。

setup 函數的工作原理

  1. 執行時機setup?函數是組件生命周期中最早執行的函數,它在?beforeCreate?和?created?生命周期鉤子之前調用。這意味著在?setup?函數內部,你無法訪問到組件的實例(this),因為此時組件實例還沒有完全創建。

  2. 參數setup?函數接收兩個參數:props?和?contextprops?是組件接收的屬性,它是一個響應式對象,你可以在?setup?函數內部訪問和修改它(但通常不建議直接修改 props)。context?是一個包含了組件的上下文信息的對象,它提供了如?attrsslotsemit?等屬性的訪問。

  3. 返回值setup?函數應該返回一個對象,這個對象中的屬性和方法將被暴露給組件的模板和其他組合式 API 函數。返回的對象可以包含響應式數據、計算屬性、方法、偵聽器等。

  4. 響應式系統:在?setup?函數內部,你可以使用 Vue 3 的響應式 API(如?reactiverefcomputed?等)來創建和管理響應式數據。這些數據在組件更新時將自動更新,無需手動觸發更新。

  5. 組合邏輯:通過使用?setup?函數,你可以將相關的邏輯代碼組織在一起,形成一個可復用的函數(也稱為 “composition function”)。這些函數可以接收參數并返回響應式數據和方法,從而在不同的組件之間共享和重用邏輯。

  6. 與模板的交互:在?setup?函數中定義的響應式數據和方法可以通過模板中的插值表達式、指令和事件處理器等方式與模板進行交互。這使得開發者可以更加直觀地管理組件的狀態和行為。

  7. 與其他選項的交互:雖然?setup?函數是組合式 API 的核心部分,但它并不完全替代了 Vue 2 中的選項式 API。例如,你仍然可以在組件中使用?methodscomputeddata?等選項,但這些選項將與?setup?函數中定義的邏輯相互獨立。通常建議在使用組合式 API 時,將盡可能多的邏輯放在?setup?函數中處理。

示例代碼

下面是一個簡單的 Vue 3 組件示例,展示了如何使用?setup?函數:

 

vue復制代碼

<template>
<div>
<p>{{ count }}</p>
<button @click="increment">Increment</button>
</div>
</template>
<script>
import { ref } from 'vue';
export default {
setup() {
const count = ref(0); // 創建一個響應式引用,初始值為 0
function increment() {
count.value++; // 修改響應式引用的值
}
// 暴露給模板的響應式數據和方法
return {
count,
increment,
};
},
};
</script>

在這個示例中,setup?函數創建了一個名為?count?的響應式引用和一個名為?increment?的方法。這些方法通過返回的對象暴露給模板,使得模板可以訪問和響應這些數據和方法。當點擊按鈕時,increment?方法被調用,從而更新?count?的值,并觸發組件的重新渲染。

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

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

相關文章

Python光速入門 - Flask輕量級框架

FlASK是一個輕量級的WSGI Web應用程序框架&#xff0c;Flask的核心包括Werkzeug工具箱和Jinja2模板引擎&#xff0c;它沒有默認使用的數據庫或窗體驗證工具&#xff0c;這意味著用戶可以根據自己的需求選擇不同的數據庫和驗證工具。Flask的設計理念是保持核心簡單&#xff0c…

布隆過濾器實戰

一、背景 本篇文章以解決實際需求的問題的角度進行切入&#xff0c;探討了如果使用布隆過濾器快速丟棄無效請求&#xff0c;降低了系統的負載以及不必要的流量。 我們都知道布隆過濾器是以占用內存小&#xff0c;同時也能夠實現快速的過濾從而滿足我們的需求&#xff0c;本篇…

Matlab偏微分方程擬合 | 源碼分享 | 視頻教程

專欄導讀 作者簡介&#xff1a;工學博士&#xff0c;高級工程師&#xff0c;專注于工業軟件算法研究本文已收錄于專欄&#xff1a;《復雜函數擬合案例分享》本專欄旨在提供 1.以案例的形式講解各類復雜函數擬合的程序實現方法&#xff0c;并提供所有案例完整源碼&#xff1b;2.…

反編譯代碼格式處理

反編譯代碼格式處理 背景解決方案程序跑之后idea格式化 總結 背景 想看看公司里一個工具的代碼實現&#xff0c;手里只有一個jar包&#xff0c;只能通過jd-gui反編譯代碼。但是呢&#xff0c;源碼是有了&#xff0c;但是看的很難受。 解決方案 /*** 替換 {code searchDir}中…

LeetCode 100231.超過閾值的最少操作數 I

給你一個下標從 0 開始的整數數組 nums 和一個整數 k 。 一次操作中&#xff0c;你可以刪除 nums 中的最小元素。 你需要使數組中的所有元素都大于或等于 k &#xff0c;請你返回需要的 最少 操作次數。 示例 1&#xff1a; 輸入&#xff1a;nums [2,11,10,1,3], k 10 輸…

Linux課程四課---Linux開發環境的使用(自動化構建工具-make/Makefile的相關)

作者前言 &#x1f382; ??????&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f382; ?&#x1f382; 作者介紹&#xff1a; &#x1f382;&#x1f382; &#x1f382; &#x1f389;&#x1f389;&#x1f389…

用Java語言創建的Spring Boot項目中,如何傳遞數組呢??

問題&#xff1a; 用Java語言創建的Spring Boot項目中&#xff0c;如何傳遞數組呢&#xff1f;&#xff1f; 在這個思路中&#xff0c;其實&#xff0c;Java作為一個后端開發的語言&#xff0c;沒必要著重于如何傳入&#xff0c;我們主要做的便是對傳入的數組數據進行處理即可…

解決虛擬機啟動報錯:“End kernel panic - not syncing: attempted to kill the idle task”

原本能正常運行的虛擬機&#xff0c;很長一段時間沒用后&#xff0c;今天再次啟動&#xff0c;然后就出現下面的問題&#xff1a; 然后走了一些彎路&#xff0c;比如說刪除該虛擬機然后新建一個虛擬機&#xff08;問題未解決&#xff09;、直接刪除VitualBox重新安裝&#xff0…

感染了后綴為.faust勒索病毒如何應對?數據能夠恢復嗎?

導言&#xff1a; 在網絡安全領域&#xff0c;.faust勒索病毒是近期備受關注的一種惡意軟件。這種病毒采用高度復雜的加密算法&#xff0c;將受感染計算機上的文件全部加密&#xff0c;并要求受害者支付贖金以獲取解密密鑰。.faust勒索病毒的攻擊方式通常是通過電子郵件附件、…

快遞平臺獨立版小程序源碼|帶cps推廣營銷流量主+前端

源碼介紹&#xff1a; 快遞代發快遞代寄寄件小程序可以對接易達云洋一級總代 快遞小程序&#xff0c;接入云洋/易達物流接口&#xff0c;支持選擇快遞公司&#xff0c;三通一達&#xff0c;極兔&#xff0c;德邦等&#xff0c;功能成熟 如何收益: 1.對接第三方平臺成本大約4元…

Python基本數據類型介紹

Python 解釋 Python是一種高級編程語言&#xff0c;以其簡潔、易讀和易用而聞名。它是一種通用的、解釋型的編程語言&#xff0c;適用于廣泛的應用領域&#xff0c;包括軟件開發、數據分析、人工智能等。python是一種解釋型&#xff0c;面向對象、動態數據類型的高級程序設計…

00X集——vba獲取CAD圖中圖元類名objectname

在CAD中&#xff0c;通過快捷鍵PL&#xff08;即POLYLINE命令&#xff09;繪制的線屬于AcDbPolyline。AcDbPolyline也被稱為LWPOLYLINE&#xff0c;即簡單Polyline&#xff0c;它所包含的對象在本身內部。 此外&#xff0c;CAD中還有另一種二維多段線對象&#xff0c;稱為AcDb2…

ViewModel 原理

在現代Android應用開發中&#xff0c;ViewModel是架構組件庫的一個關鍵部分&#xff0c;它在提高應用的穩定性和性能方面發揮著重要作用。在這篇文章中&#xff0c;我們將深入探討ViewModel的工作原理和最佳實踐。 ViewModel簡介 ViewModel是Android Jetpack架構組件的一部分…

ubuntu安裝Avahi發現服務工具

一、簡介 解決設置固定ip后無法連接外網的問題&#xff0c;目前采用動態獲取ip&#xff0c;可以不用設置設備的固定IP&#xff0c;直接可以通過域名來訪問設備&#xff0c;類似樹莓派的連接調試 二、安裝 本文使用的是ubuntu23.10.1上安裝 1.安裝工具 sudo apt install av…

2.模擬問題——4.日期問題

日期問題難度并不大&#xff0c;但是代碼量非常大&#xff0c;需要較高的熟練度&#xff0c;因此需要著重練習&#xff0c;主要涉及數組和循環兩個方面的知識點&#xff0c;需要熟練的測試代碼。 兩個經典題型 閏年 閏年滿足以下兩個條件的任意一個 能夠被400整除不能夠被1…

MyBatis攔截器實現打印完整SQL語句

我們在執行語句的時候會使用Mybatis自帶的日志打印工具&#xff0c;但是打印的時候參數會用?代替&#xff0c;顯得看起來不是那么直觀&#xff0c;所以通過實現了InnerInterceptor接口&#xff0c;并重寫了beforeQuery和beforeUpdate方法。在這兩個方法中&#xff0c;它會獲取…

【Acwing】差分矩陣

圖1&#xff1a;a和b數組映射表 由于a是b的前綴和數組&#xff0c;因此改變b[ x1][ y1]之后&#xff0c;受到影響的a中元素如右半圖所示 圖2&#xff1a;求b數組的前綴和 #include<bits/stdc.h> using namespace std;int n,m,q; int a[1010][1010]; int b[1010][1010]…

work 3/1

1>機械臂 #include <head.h> #define SER_POTR 8899 #define SER_IP "192.168.125.223" int main(int argc, const char *argv[]) {//創建套接字int cfdsocket(AF_INET,SOCK_STREAM,0);if(cfd-1){perror("");return -1;}//鏈接struct sockaddr_i…

一文搞懂瀏覽器緩存機制

文章目錄 概述強制緩存協商緩存總結參考文章 概述 瀏覽器的緩存機制也就是我們說的HTTP緩存機制&#xff0c;其機制是根據HTTP報文的緩存標識進行的 瀏覽器第一次向服務器發送HTTP請求, 瀏覽器拿到請求結果后&#xff0c;會根據響應報文的緩存標識&#xff0c;決定是否進行緩存…

機器學習:數據處理基操

在處理完數據之后&#xff0c;選擇好模型&#xff0c;就可以用訓練集訓練模型&#xff0c;用測試集輸入模型 然后輸出需要預測的結果啦&#xff5e; 一、模塊導入 import numpy as np import pandas as pd #讀入數據 二、pandas數據 一、dataframe基礎 一、dataframe的創建…