vue實例 與組件實例

vue實例 與組件實例流程圖

在這里插入圖片描述

🧩 基本解釋

? Vue 實例

Vue 實例是通過 new Vue({…}) 創建的對象,是整個應用的根節點。

const vm = new Vue({el: '#app',data: { msg: 'Hello Vue' }
});
  • 是整個應用的起點。
  • 只有一個根 Vue 實例(通常)。
  • 控制整個頁面或應用結構。

? 組件實例(Component Instance)

組件實例是通過注冊組件后,在頁面中 被創建出來的實例。

Vue.component('MyComp', {props: ['msg'],template: '<div>{{ msg }}</div>'
});<my-comp msg="hello" />
  • 每個 會創建一個組件實例。
  • 實際上是 Vue 的子類實例(通過 Vue.extend 實現)。
  • 每個組件實例都有自己的作用域、數據、方法、生命周期。

📌 核心區別與聯系

特性Vue 實例組件實例
創建方式new Vue()Vue.extend() 后 new SubComponent()
作用整體應用入口頁面中一個局部功能單元
是否唯一否,可以有多個
是否可嵌套否(根)可以嵌套
生命周期鉤子有(幾乎一致)
el 選項必須/可選無(父組件控制掛載)

🧬 深入機制對比(Vue 2 源碼視角)

? Vue 實例創建流程(new Vue())

function Vue(options) {this._init(options); // 初始化邏輯
}

內部核心流程:

vm._init() =>mergeOptions =>initLifecycle =>initEvents =>initRender =>callHook(vm, 'beforeCreate') =>initState (data/props/computed/watcher) =>callHook(vm, 'created') =>vm.$mount(el) => 渲染、patch 掛載到 DOM

? 組件實例創建流程(通過模板解析出來)

在編譯模板 → render → VNode → patch 時,會創建組件實例:

createComponent(VNode, ...) =>const Ctor = Vue.extend(options) =>const instance = new Ctor({ ... }) // 組件實例

也會調用 _init(),和根 Vue 實例一樣的初始化過程!

所以組件實例其實和 Vue 實例沒有本質差別,只是繼承而來的子類實例。

? 組件與 Vue 實例共同點(來自 _init())

  • 生命周期鉤子(created、mounted 等)
  • 響應式系統(data、props)
  • 渲染流程(render → vnode → patch)
  • w a t c h 、 watch、 watchset、$emit 等實例方法

🔍 組件實例的額外特點

  • props:通過 initProps() 初始化。
  • 父子關系:有 $parent, $children,用于組件通信。
  • scoped slot、$refs、動態組件等擴展能力。

🔁 Vue 3 差異(簡要對比)

特性Vue 2Vue 3
創建 Vue 實例new Vue()createApp()
組件實現方式Vue.extend() + 構造函數函數組件 + Proxy
響應式系統Object.definePropertyProxy
Setup 函數?? 核心入口,組件邏輯編寫點

?

Vue 3 中 Vue 與組件的統一性更強:

// Vue 3 root
createApp(App).mount('#app');

App 本身就是組件,和子組件機制一致。

? 總結

結論點內容
本質 組件實例是Vue 實例的“子類實例”
初始化方式都調用 _init() 進行統一初始化
區別點Vue 實例是入口、組件實例是功能塊,具有父子關系
Vue 3通過函數式 API 統一組件與實例創建方式

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

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

相關文章

Hive 分桶(Bucketing)深度解析:原理、實戰與核心概念對比

一、分桶的意義&#xff1a;比分區更細的粒度管理 1.1 解決分區數據不均勻問題 分區的局限性&#xff1a;分區基于表外字段&#xff08;如時間字段&#xff09;劃分數據&#xff0c;但可能導致部分分區數據量過大&#xff0c;部分過小&#xff0c;無法進一步細化。 分桶的定…

pytest+allure+allure-pytest 報告輸出遇到的問題匯總

文章目錄 前言問題一&#xff1a;module allure has no attribute severity_level問題二&#xff1a;ERROR:file or directory not found: ‐vs問題三&#xff1a;生成的 html 報告是空的&#xff0c;明明有測試用例執行完成&#xff0c;但報告沒有顯示數據 前言 pytestallure…

升級node@22后運行npm install報錯 distutils not found

從node20升級到node22后&#xff0c;在運行 npm install 的時候報了很多 gyp 錯誤&#xff0c;其中包括 npm error npm error ModuleNotFoundError: No module named distutils。 問題原因是我在使用 brew install node22 的過程中自動把 python 升級到了 3.13。而 distutils …

IPD流程落地:項目任務書Charter開發

目錄 簡介 第一個方面&#xff0c;回答的是Why的問題。 第二點&#xff0c;要回答做什么的問題&#xff0c;也就是產品定義What的問題。 第三點就是要回答執行策略與計劃的問題&#xff0c;也就是How、When、Who的問題。 第四點是對上述這些分析的總結分析&#xff0c;要為…

Qt popup窗口半透明背景

半透明彈窗需要paintEvent()接口支持 方法一&#xff1a;使用setStyleSheet設置半透明樣式&#xff0c;如果是子窗口&#xff0c;則可注釋構建函數內屬性設置 class TranslucentWidget : public QWidget { public: explicit TranslucentWidget(QWidget *parent nullptr)…

Excel快捷鍵大全

Excel快捷鍵 工作表操作快速選擇區域快速跳轉/視圖操作單元格公式批量填充與編輯功能鍵打開/關閉工作簿 工作表操作 快捷鍵功能ShiftF11(或Alt→H→I→S)默認插入新工作表到當前工作表左側的左側Alt→E→L→Enter刪除當前工作表&#xff0c;刪除后不可銷&#xff0c;須謹慎操作…

SQLMesh 用戶定義變量詳解:從全局到局部的全方位配置指南

SQLMesh 提供了靈活的多層級變量系統&#xff0c;支持從全局配置到模型局部作用域的變量定義。本文將詳細介紹 SQLMesh 的四類用戶定義變量&#xff08;global、gateway、blueprint 和 local&#xff09;以及宏函數的使用方法。 一、變量類型概述 SQLMesh 支持四種用戶定義變量…

爬蟲學習-Scrape Center spa6 超簡單 JS 逆向

關卡 spa6 電影數據網站&#xff0c;無反爬&#xff0c;數據通過 Ajax 加載&#xff0c;數據接口參數加密且有時間限制&#xff0c;適合動態頁面渲染爬取或 JavaScript 逆向分析。 首先抓包發現get請求的參數token有加密。 offset表示翻頁&#xff0c;limit表示每一頁有多少…

webtrees——在線協作家譜

webtrees——在線協作家譜 內容 執照編碼風格和標準介紹系統要求互聯網瀏覽器兼容性安裝升級建設與發展Gedcom&#xff08;家譜&#xff09;文件安全備份從備份還原 執照 webtrees&#xff1a;在線家譜版權所有 2022 webtrees 開發團隊 該程序是免費軟件&#xff1a;您可以根據…

day 37

模型的保存和加載 僅保存模型參數 - 原理&#xff1a;保存模型的權重參數&#xff0c;不保存模型結構代碼。加載時需提前定義與訓練時一致的模型類。 - 優點&#xff1a;文件體積小&#xff08;僅含參數&#xff09;&#xff0c;跨框架兼容性強&#xff08;需自行定義模型結…

MFC:獲取所有打印機的名稱(打印機模塊-2)

背景&#xff1a; “遍歷當前用戶的每一臺虛擬打印機&#xff0c;將其默認紙張設置為 A4 并設置為縱向。” 實現原理&#xff1a; 1.從當前用戶的注冊表讀取所有已配置的打印機&#xff1b; 2.遍歷每臺打印機&#xff1b; 3.輸出其邏輯與實際紙張大小&#xff1b; 4.嘗試設置…

Python驅動的游戲場景實時生成:如何用AI創造無限可能?

友友們好! 我是Echo_Wish,我的的新專欄《Python進階》以及《Python!實戰!》正式啟動啦!這是專為那些渴望提升Python技能的朋友們量身打造的專欄,無論你是已經有一定基礎的開發者,還是希望深入挖掘Python潛力的愛好者,這里都將是你不可錯過的寶藏。 在這個專欄中,你將會…

手機發熱怎么辦?

1?關閉后臺程序 &#x1f449; 把后臺運行的其他程序關掉&#xff0c;玩游戲或看視頻前&#xff0c;先清理一下后臺&#xff0c;避免發熱 2?“脫掉”手機殼 &#x1f449;夏天可以換成輕薄的散熱殼&#xff0c;比如金屬、亞克力材質的&#xff0c;或者暫時取下手機殼 3?物理…

【安全攻防與漏洞?】??HTTPS中的常見攻擊與防御??

HTTPS 中常見攻擊與防御策略涵蓋中間人攻擊&#xff08;MITM&#xff09;、SSL剝離、重放攻擊等&#xff0c;幫助構建安全的 HTTPS 通信環境&#xff1a; 一、中間人攻擊&#xff08;MITM&#xff09; 攻擊原理 場景&#xff1a;攻擊者通過偽造證書或劫持網絡流量&#xff0c…

如何搭建perfino監控(分析java服務性能)

本文主要解釋如何搭建perfino監控服務, 用于關注生產環境的性能指標, 提前知道什么時候達到服務器資源瓶頸, 避免資源不足時手忙腳亂~ 1. 安裝與部署? ??1. 下載與安裝? ?官網下載?&#xff1a;Perfino 官網 獲取最新版本&#xff08;支持 Windows/Linux/macOS&#xf…

5 分鐘速通密碼學!

讓我們開始第一部分&#xff1a;密碼學基礎 (Cryptography Basics)。 第一部分&#xff1a;密碼學基礎 (Cryptography Basics) 1. 什么是密碼學&#xff1f; 想象一下&#xff0c;在古代戰爭中&#xff0c;將軍需要向遠方的部隊傳遞作戰指令。如果直接派人送信&#xff0c;信…

MyBatis入門:快速搭建數據庫操作框架 + 增刪改查(CRUD)

一、創建Mybatis的項目 Mybatis 是?個持久層框架, 具體的數據存儲和數據操作還是在MySQL中操作的, 所以需要添加MySQL驅動 1.添加依賴 或者 手動添加依賴 <!--Mybatis 依賴包--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactI…

基于Ubuntu的ros版本切換

解決在同一個虛擬機中管理兩個不同版本的ros 基于Ubuntu&#xff08;20.04&#xff09; ros版本1和版本2的切換 前期準備&#xff1a;已經在Ubuntu中安裝了兩個版本的ros&#xff0c;這里以版本1的noetic和版本2的foxy為例 在bashrc中&#xff1a; # ~/.bashrc: executed by…

vue2:橫向無限輪播

子組件 <template><div class"infinite-scroll" ref"scrollContainer"><div class"scroll-content" :style"{ transform: translateX(${scrollPosition}px) }"><div v-for"(item, index) in displayItems&q…

CVE-2021-44228源碼分析與漏洞復現

漏洞概述 漏洞名稱&#xff1a;Apache Log4j2 遠程代碼執行漏洞 漏洞編號&#xff1a;CVE-2021-44228 CVSS 評分&#xff1a;10.0 影響版本&#xff1a;Apache Log4j 2.0-beta9 至 2.14.1 修復版本&#xff1a;2.15.0、2.16.0 CVE-2021-44228 是 Apache Log4j2 日志框架中因 …