提效-點擊跳轉到源碼

1、localhost項目

例如【鯨島】這個中臺項目啟動地址是localhost。

使用chrome中的【click-to-react-component 】擴展, alt + 鼠標左鍵 選擇dom后跳轉到對應文件。

click-to-react-component的原理(來自ai)

click-to-react-component 的工作原理確實很巧妙,讓我來解釋一下:

  1. React DevTools 集成

// 利用 React DevTools 提供的能力
window.__REACT_DEVTOOLS_GLOBAL_HOOK__
  • 通過 Chrome 擴展機制,獲取頁面中的 React Fiber 樹

  • 可以訪問到組件的內部信息,包括源碼位置

  1. 源碼映射(Source Maps)

// 開發環境下 webpack 會生成 source map
//# sourceMappingURL=main.js.map
  • 利用瀏覽器開發者工具提供的 source map API

  • 可以將編譯后的代碼位置映射回源代碼位置

  1. DOMReact 組件的映射

// 簡化的原理示意
document.addEventListener('mouseover', (e) => {// 獲取 DOM 元素對應的 React Fiberconst fiber = getFiberFromDOM(e.target);// 通過 fiber 獲取源碼位置const sourceLocation = getSourceLocation(fiber);
});

  1. 編輯器通信

// 使用特殊協議打開編輯器
window.open(`vscode://file/${filePath}:${line}:${column}`);

主要區別:

  1. code-inspector-plugin 需要在構建時注入信息

  2. click-to-react-component 利用已有的開發工具基礎設施

    1. React DevTools

    2. Source Maps

    3. Chrome 擴展 API

這就是為什么 click-to-react-component 不需要修改項目代碼就能工作,因為它巧妙地利用了開發環境下已經存在的這些工具和信息。

2、非localhost項目

比如fs這類電商項目,這里使用 code-inspector 的打包插件。

使用

  1. 安裝npm插件

npm install code-inspector-plugin -D 
//其他包版本過低就用命令:  npm install code-inspector-plugin -D --legacy-peer-deps

  1. 在打包中使用這個插件

fs中修改configs/webpack.dev.js


const { codeInspectorPlugin } = require('code-inspector-plugin');plugins: [codeInspectorPlugin({bundler: 'webpack',}),]

  1. 項目啟動后用 shift + alt + 鼠標左鍵 選擇組件

原理(來自ai)

讓我來解釋一下 code-inspector 的核心工作原理:

  1. 編譯時注入

  • 通過 webpack/vite 等構建工具的插件系統,在編譯過程中為每個組件注入位置信息

  • 主要包含:文件路徑、行號、列號等源碼位置信息

  1. 運行時定位

// 簡化的原理示意
{// 開發環境下會注入類似這樣的代碼__CODE_INSPECTOR__: {filePath: 'src/components/Button.jsx',line: 10,column: 5}
}

  1. 事件監聽

  • 監聽組合鍵(Alt+Shift)的按下

  • 添加鼠標移動事件監聽器

  • 在 DOM 元素上顯示遮罩層和位置信息

  1. IDE 通信

  • 使用 vscode:// 等協議打開編輯器

  • 通過 URL 參數傳遞文件路徑和位置信息

  • 編輯器接收到請求后定位到對應位置

  1. 開發環境限制

if (process.env.NODE_ENV === 'development') {// 只在開發環境下注入代碼plugins.push(['code-inspector-plugin', {bundler: 'webpack'}]);
}

主要優點:

  1. 無侵入性 - 不需要修改源代碼

  2. 性能影響小 - 只在開發環境生效

  3. 支持多種框架 - React/Vue/Svelte 等

這就是為什么在你的 babel 配置中需要添加這個插件,它需要在編譯階段注入必要的位置信息。

其他類似的插件

  1. locatorjs,這個插件提供chrome擴展

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

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

相關文章

FeignClient發送https請求時的證書驗證原理分析

背景 微服務之間存在調用關系,且部署為 SSL 協議時,Feignt 請求報異常: Caused by: javax.net.ssl.SSLHandshakeException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find vali…

性能優化關鍵:link、script和meta的正確打開方式

link 標簽的主要屬性及其作用 屬性是否必填作用描述示例值rel是定義當前文檔與鏈接資源的關系(必須屬性)。常見值:stylesheet, icon, preload, preconnect 等。rel"stylesheet" rel"icon"href是指定鏈接資源的URL。href…

Linux `less` 命令深度解析與高階應用指南

Linux `less` 命令深度解析與高階應用指南 一、核心功能解析1. 基本作用2. 與類似工具對比二、選項系統詳解1. 常用基礎選項2. 高階選項組合三、高階應用場景1. 日志分析系統2. 代碼審查系統3. 數據管道處理四、特殊文件處理1. 大文件優化查看2. 二進制文件分析五、交互式命令大…

影刀RPA-20-高級操作題2

一、題目 二、鏈接 方法一:影刀應用分享: 高級考試題2-第二次 方法二:影刀應用分享: 高級考試題2 三、代碼 方法一: import xbot from xbot import print, sleep from .import package from .package import variables as glv from xbot…

C# NX二次開發-獲取面法向和UV等數據

通過ufun函數UF_MODL_ask_face_props可以獲取到面的法向數據和UV和半徑等數據。 代碼如下: double[] uvs new double[4];double[] param new double[2];double[] point new double[3];double[] u1 new double[3];double[] v1 new double[3];double[] u2 new d…

SpringBoot整合Sa-Token:實現RBAC權限模型

Java系列文章 文章目錄 Java系列文章前言一、基礎概念1.1 RBAC模型核心概念1.2 Sa-Token核心功能1.3 環境準備 二、表結構設計2.1 ER圖示例2.2 數據庫表設計2.2.1 用戶表2.2.2 角色表2.2.3 部門表2.2.4 權限表 三、SpringBoot整合Sa-Token3.1 sa-token基礎配置3.1.1 Maven配置3…

工商業儲能的“智慧大腦”:解密 Acrel-2000ES EMS 的核心功能與價值

安科瑞電氣顧強 市場背景:工商業儲能加速崛起 2022年中國已并網的儲能項目中,用戶側并網占比為8.36%,其中工商業儲能占據了用戶側高達98.6%的份額。驅動這一市場發展的關鍵因素日益顯著: 1.峰谷價差擴大: 全國各省市…

vue+threeJs 根據屏幕調整gltf模型的大小、重心、并更換騎車整體顏色

嗨,我是小路。今天主要和大家分享的主題是“vuethreeJs 根據屏幕調整gltf模型的大小、重心、并更換騎車整體顏色”。 項目案例示意圖 1.整體更換gltf模型的顏色 定義:整體代碼如下。顏色是事先設定的 const colorAry reactive(["rgb(21…

03 基于 java udp 做一個dns服務器 和 一個dns代理服務器

前言 這個也是 來自于一個朋友的需求 最終的目的是實現一個 dns 代理服務器, 當然 這本質也是一個 dns 服務器 并且 dns 代理服務器是依賴于 一個 dns 服務器的, 因此 順便給一個 dns 服務器的 demo 這里 主要是 基于 udp 的一個 dns 請求, 響應數據的交互 dns 服務器 …

【HITCSAPP 哈工大計算機系統期末大作業】 程序人生-Hello’s P2P

計算機系統 大作業 題 目 程序人生-Hello’s P2P 專 業 計算機與電子通信類 學   號 2023112915 班   級 23L0505 學 生 楊昕彥 指 導 教 師 劉宏偉 計算機科學…

第十周作業

一、CSRF 1、DVWA-High等級 2、使用Burp生成CSRF利用POC并實現攻擊 二、SSRF:file_get_content實驗,要求獲取ssrf.php的源碼 三、RCE 1、 ThinkPHP 2、 Weblogic 3、Shiro

PTA刷題筆記(難度預警!!!有詳解)

7-18 二分法求多項式單根 代碼如下&#xff1a; ? #include <stdio.h> #include <math.h>// 定義多項式函數 double polynomial(double x, double a3, double a2, double a1, double a0) {return a3 * x * x * x a2 * x * x a1 * x a0; }// 二分法求根函數 do…

打破傳統范式,線上 3D 畫展彰顯多元亮點

&#xff08;一&#xff09;沉浸式體驗&#xff0c;身臨其境賞畫? 線上 3D 畫展運用先進的 3D 建模和虛擬現實&#xff08;VR&#xff09;技術&#xff0c;高度還原了真實的展廳環境 。展廳內的布局、燈光&#xff0c;甚至墻壁的質感都被完美復刻&#xff0c;讓觀眾仿佛置身于…

Docker架構詳解

一,Docker的四大要素&#xff1a;Dockerfile、鏡像(image)、容器(container)、倉庫(repository) 1.dockerfile&#xff1a;在dockerfile文件中寫構建docker的命令,通過dockerbuild構建image 2.鏡像&#xff1a;就是一個只讀的模板&#xff0c;鏡像可以用來創建docker容器&…

【工具類】常用的工具類——CollectionUtil

目錄 cn.hutool.core.collection.CollectionUtil集合創建集合清空集合判空集合去重集合過濾集合轉換集合合并集合交集集合差集集合是否包含元素集合是否包含指定元素&#xff08;自定義條件&#xff09;集合分頁集合分組集合轉字符串元素添加元素刪除根據屬性轉Map獲取元素獲取…

從零起步搭建基于華為云構建碳排放設備管理系統的產品設計

目錄 &#x1f33f; 華為云 IoT&#xff1a;輕松上手碳排放設備管理系統搭建 &#x1f30d; 逐步搭建搭建規劃 &#x1f680; 一、系統藍圖&#xff1a;5大核心模塊&#xff0c;循序漸進 1?? 設備管理與數據采集層 2?? 數據傳輸與協議轉換層 3?? 數據處理與分析層…

華為OD機試真題—— 小明減肥(2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳實現

2025 B卷 100分 題型 本專欄內全部題目均提供Java、python、JavaScript、C、C++、GO六種語言的最佳實現方式; 并且每種語言均涵蓋詳細的問題分析、解題思路、代碼實現、代碼詳解、3個測試用例以及綜合分析; 本文收錄于專欄:《2025華為OD真題目錄+全流程解析+備考攻略+經驗分…

數據結構 -- 插入排序(直接插入排序和希爾排序)

插入排序 算法思想 每次將?個待排序的記錄按其關鍵字大小插入到前面已排好序的子序列中&#xff0c;直到全部記錄插入完成。 代碼實現 void InsertSort(int A[],int n){int i,j,temp;for(i 1;i<n;i){if(A[i]<A[i-1]){temp A[i]; //用temp暫存A[i]for(ji-1;j>…

word中表格拉不動以及插入圖片有間距

word中的表格寬度和高度怎么調整都改不了&#xff0c;可以將選中表格—右鍵—段落—取消勾選下圖中的兩項。 word中表格插入圖片始終有間隙&#xff0c;怎么也消除不了間隙&#xff0c;可以在表布局—單元格邊距—修改上下左右邊距為0即可

網絡抓包命令tcpdump及分析工具wireshark使用

文章目錄 環境文檔用途詳細信息 環境 系統平臺&#xff1a;Linux x86-64 Red Hat Enterprise Linux 8,Linux x86-64 Red Hat Enterprise Linux 7,Linux x86-64 SLES 12,銀河麒麟 &#xff08;鯤鵬&#xff09;,銀河麒麟 &#xff08;X86_64&#xff09;,銀河麒麟&#xff08;龍…