npm link 命令解析


 文字轉的

對開發者而言,這算是最有價值的命令。假設我們開發了一個模塊叫 test ,然后我們在 test-example 里引用這個模塊 ,每次 test 模塊的變動我們都需要反映到 test-example 模塊里。不要擔心,有了 npm link 命令一切變的非常容易。

首先我們需要把 test 鏈接到全局模式下:

cd ~/work/node/test # 進入test模塊目錄
npm link # 創建鏈接到$PREFIX/lib/node_modules

那么 test 的模塊將被鏈接到 $PREFIX/lib/node_modules 下,就像我的機器上 $PREFIX 指到 /usr/local ,那么 /usr/local/lib/node_modules/test 將會鏈接到 ~/work/node/test 下。執行腳本 bin/test.js 被鏈接到 /usr/local/bin/test 上。

接下來我們需要把 test 引用到 test-example 項目中來:

cd ~/work/node/test-example # 進入test-example模塊目錄
npm link test # 把全局模式的模塊鏈接到本地

npm link test 命令會去 $PREFIX/lib/node_modules 目錄下查找名叫 test 的模塊,找到這個模塊后把 $PREFIX/lib/node_modules/test 的目錄鏈接到 ~/work/node/test-example/node_modules/test 這個目錄上來。

現在任何 test 模塊上的改動都會直接映射到 test-example 上來。

 

再比如假設我們開發很多應用,每個應用都用到 Coffee-script :

npm install coffee-script -g # 全局模式下安裝coffee-script
cd ~/work/node/test # 進入開發目錄
npm link coffee-script # 把全局模式的coffee-script模塊鏈接到本地的node_modules下
cd ../test-example # 進入另外的一個開發目錄
npm link coffee-script # 把全局模式的coffee-script模塊鏈接到本地
npm update coffee-script -g # 更新全局模式的coffee-script,所有link過去的項目同時更新了。

 

 

 

原理  linux的系統下會自動執行ln -s 命令來創建一個軟連接指向你的全局包路徑

 

這么一定段文字有點繞。下面用畫圖解釋一下 

 

例:

test-example 使用需要 test模塊,就是上文紅色文字

 

 

例2 :每個應用都用到 Coffee-script 上文藍色字

 

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM