Vue React

Vue 的源碼主要分為以下幾個部分:

主要涉及 響應式、虛擬 DOM、組件系統、編譯器、運行時

├── packages/
│   ├── compiler-core/    # 編譯器核心
│   ├── compiler-sfc/     # 處理 .vue 單文件組件
│   ├── compiler-dom/     # 處理 DOM 相關的編譯邏輯
│   ├── reactivity/       # 響應式系統
│   ├── runtime-core/     # 運行時核心
│   ├── runtime-dom/      # 運行時 DOM 相關
│   ├── shared/           # 共享工具函數
│   ├── vue/              # Vue 入口
│   └── ...

React 源碼結構:

整體架構可以分為 調度(Scheduler)、協調(Reconciler)、渲染(Renderer) 三個核心部分

可以從 React 入口、Fiber 架構、調度機制、Hooks 實現、Diff 算法 等方面解析其核心原理。

├── packages/
│   ├── react/            # React 核心 API(React.createElement、hooks)
│   ├── react-dom/        # 負責渲染到 DOM
│   ├── scheduler/        # 調度器,控制任務優先級
│   ├── react-reconciler/ # 負責 Fiber 樹的協調和 Diff
│   ├── shared/           # 公共方法
│   ├── jest/             # 測試相關
│   └── ...

?Fiber 是 React 16 引入的核心數據結構,每個組件對應一個 Fiber 節點:

function FiberNode(tag: WorkTag,pendingProps: mixed,key: null | string,mode: TypeOfMode,
) {// 實例相關this.tag = tag;           // 組件類型(Function/Class/Host等)this.key = key;           // key屬性this.elementType = null;  // 創建元素的類型this.type = null;         // 組件函數/類this.stateNode = null;    // 對應的真實DOM實例/類組件實例// Fiber樹結構this.return = null;       // 父Fiberthis.child = null;        // 第一個子Fiberthis.sibling = null;      // 兄弟Fiberthis.index = 0;           // 在兄弟中的索引// 狀態相關this.pendingProps = pendingProps;this.memoizedProps = null;this.updateQueue = null;  // 狀態更新隊列this.memoizedState = null;// 當前狀態// 副作用this.effectTag = NoEffect;this.nextEffect = null;   // 下一個有副作用的Fiber// 雙緩存技術this.alternate = null;    // 連接current和workInProgress樹
}

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

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

相關文章

項目實戰--權限列表

后端數據: 用表格實現權限列表 const dataSource [{key: 1,name: 胡彥斌,age: 32,address: 西湖區湖底公園1號,},{key: 2,name: 胡彥祖,age: 42,address: 西湖區湖底公園1號,}, ];const columns [{title: 姓名,dataIndex: name,key: name,},{title: 年齡,dataInd…

私有知識庫 Coco AI 實戰(一):Linux 平臺部署

Coco AI 是一個完全開源、跨平臺的統一搜索和生產力工具,能夠連接各種數據源,包括應用程序、文件、Google Drive、Notion、Yuque、Hugo 等,幫助用戶快速智能地訪問他們的信息。通過集成 DeepSeek 等大型模型,Coco AI 實現了智能個…

【大模型】微調一個大模型需要多少 GPU 顯存?

視頻鏈接:微調一個模型需要多少GPU顯存? up 主頁:AI老兵tags: #GPU顯存 #模型微調 #LoRA #QLoRA #參數計算 本集視頻詳細介紹了在模型微調過程中 GPU顯存需求的計算方法,包括全量微調和高效微調(如 LoRA&am…

Lambda 表達式是什么以及如何使用

目錄 📌 Kotlin 的 Lambda 表達式詳解 🎯 什么是 Lambda 表達式? 🔥 1. Lambda 表達式的基本語法 ? 示例 1:Lambda 基本寫法 ? 示例 2:使用 it 關鍵字(單參數簡化) ? 示例 3…

全文 MLIR TOY -- Chapter2: 發出基本的 MLIR——把AST變成SSA的 MLIR Dialect IR

現在我們已經熟悉 Toy 語言和它的AST表示,現在讓我們看看 MLIR 是怎樣幫助編譯 Toy 源程序的。 簡介:多層中間表示 其他的編譯器,像 LLVM,是提供一個固定的預定義類型和指令(通常是底層的像 RISC的指令)。對…

一個判斷A股交易狀態的python腳本

最近在做股票數據相關的項目,需要用到判斷某一天某個時刻A股的狀態,比如休市,收盤,交易中等,發動腦筋想了一下,這個其實還是比較簡單的,這里我把實現方法分享給大家。 思路 當天是否休市 對于某…

LLaMA Factory微調后的大模型在vLLM框架中對齊對話模版

LLaMA Factory微調后的大模型Chat對話效果,與該模型使用vLLM推理架構中的對話效果,可能會出現不一致的情況。 下圖是LLaMA Factory中的Chat的對話 下圖是vLLM中的對話效果。 模型回答不穩定:有一半是對的,有一半是無關的。 1、未…

004 健身房個性化訓練計劃——金丹期(體態改善)

個人筆記使用。 01 肱骨前移 1.放松肩前束 2.放松肩后束 2.5kg啞鈴側展 泡沫軸上下滾 招財貓 肱二頭 02 溜肩 寬距的坐姿劃船 上頂

【已開源】UniApp+vue3跨端應用從0到1開發指南、uniapp+vue3模板應用

在跨端開發日益成為主流的今天,如何高效構建規范、可維護的企業級應用?本文以UniAppVue3* *TypeScript**為核心技術棧,手把手帶你從零搭建高標準的跨平臺項目。 通過本文,你將系統掌握: ? 環境配置:Node…

線程池設計

線程池實際上也是一個生產者消費者模型&#xff0c;線程池可以讓多個線程去任務隊列中取任務&#xff0c;執行任務&#xff0c;適用于需要大量的線程來完成任務且完成任務的時間較短。 #include "log.hpp" #include <mutex> #include <condition_variable&…

黑盒測試的正交實驗法

背景: 利用因果圖法、判定表法可以幫助我們對于輸入數據的組合情況進行用例設計&#xff0c;但當輸入數據的組合數量巨大時&#xff0c;由于不太可能覆蓋到每個輸入組合的測試情況&#xff0c;因果圖法或判定表法可能就不太適用了&#xff0c;可以采用正交實驗法、來合理地減少…

Linux內核編程

linux 系 統 在 2 4 4 0 上 的 啟 動 過 程 分 三個 階 段 u-boot的啟動 1.先分清寄存器的分類 RAM的分類 ROM的分類 Mini2440開發板的存 儲器配置 Mini2440開發板板載: 1. 64MB sdram; 2. 256MB nand-flash; 3. 2MB nor-flash; 4. s3c2440內部還有4KB iram; Mini2440的啟…

黑盒測試的判定表法(能對多條件依賴關系進行設計測試點)

定義: 判定表是分析和表達多邏輯條件下執行不同操作的工具。就是指把所有的輸入條件、所有可能采取的動作按表格列出來&#xff0c;每一種條件和動作的組合構成一條規則&#xff0c;也即一條用例。 1.判定表法的引用 等價類邊界值分析法主要關注單個輸入類條件的測試并未考慮…

從零構建大語言模型全棧開發指南:第四部分:工程實踐與部署-4.1.2ONNX格式轉換與TensorRT部署

?? 點擊關注不迷路 ?? 點擊關注不迷路 ?? 點擊關注不迷路 文章大綱 從零構建大語言模型全棧開發指南-第四部分:工程實踐與部署4.1.2 ONNX格式轉換與TensorRT部署1. 模型部署的核心挑戰與價值2. ONNX格式轉換技術詳解2.1 ONNX技術棧組成2.2 轉換流程與關鍵技術2.3 轉換常…

免費下載 | 2025年網絡安全報告

報告總結了2024年的網絡安全態勢&#xff0c;并對2025年的安全趨勢進行了預測和分析。報告涵蓋了勒索軟件、信息竊取軟件、云安全、物聯網設備安全等多個領域的安全事件和趨勢&#xff0c;并提供了安全建議和最佳實踐。 一、報告背景與目的 主題&#xff1a;2024企業信息安全峰…

基于Real-Sim-Real循環框架的機器人策略遷移方法

編輯&#xff1a;陳萍萍的公主一點人工一點智能 基于Real-Sim-Real循環框架的機器人策略遷移方法本文通過嚴謹的理論推導和系統的實驗驗證&#xff0c;構建了一個具有普適性的sim-to-real遷移框架。https://mp.weixin.qq.com/s/cRRI2VYHYQUUhHhP3bw4lA 01 摘要 本文提出的Rea…

語義分析(編譯原理)

1.什么是語義分析: 前兩個階段&#xff0c;詞法分析是從字符到單詞的一級識別&#xff0c;保證了每個單詞的形式是正確的&#xff0c; 語法分析是由單詞到語法樹的一級識別&#xff0c;如果不符合語法規則就不能建樹&#xff0c;因此保證了各個語法成分的構成是正確的 詞法分…

藍橋杯備考---》貪心算法之矩陣消除游戲

我們第一次想到的貪心策略一定是找出和最大的行或者列來刪除&#xff0c;每次都更新行和列 比如如圖這種情況&#xff0c;這種情況就不如直接刪除兩行的多&#xff0c;所以本貪心策略有誤 so我們可以枚舉選的行的情況&#xff0c;然后再貪心的選擇列和最大的列來做 #include …

LeetCode hot 100—二叉搜索樹中第K小的元素

題目 給定一個二叉搜索樹的根節點 root &#xff0c;和一個整數 k &#xff0c;請你設計一個算法查找其中第 k 小的元素&#xff08;從 1 開始計數&#xff09;。 示例 示例 1&#xff1a; 輸入&#xff1a;root [3,1,4,null,2], k 1 輸出&#xff1a;1示例 2&#xff1a; …

【Java SE】Arrays類

參考筆記&#xff1a; Java中Arrays類(操作數組的工具)_java arrays-CSDN博客 Java——Arrays 類詳解_java arrays類-CSDN博客 目錄 1.Arrays類簡介 2.Arrays.toString 2.1 使用示例 2.2 源碼 3. Arrays.copyOf 3.1 使用示例 3.2 源碼 4.Arrays.sort 4.1 默認排序使…