国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 課堂 > 電腦知識 > 正文

npm install 本地安裝與全局安裝的區別

2024-05-08 15:08:24
字體:
來源:轉載
供稿:網友

  npm的包安裝分為本地安裝(local)、全局安裝(global)兩種,從敲的命令行來看,差別只是有沒有-g而已,比如

  npm install grunt # 本地安裝

  npm install -g grunt-cli # 全局安裝

  這兩種安裝方式有什么區別呢?從npm官方文檔的說明來看,主要區別在于(后面通過具體的例子來說明):

  本地安裝

  1. 將安裝包放在 ./node_modules 下(運行npm時所在的目錄)

  2. 可以通過 require() 來引入本地安裝的包

  全局安裝

  1. 將安裝包放在 /usr/local 下

  2. 可以直接在命令行里使用

  本地安裝

  1、將安裝包放在 ./node_modules 下(運行npm時所在的目錄)

  比如運行下面命令

  npm install grunt --save-dev

  那么,就會在當前目錄下發現一個node_modules目錄,進去后能夠看到grunt這個包

  casperchenMacBookPRo:testUsemin casperchen$ ll

  total 200

  drwxr-xr-x 16 casperchen staff 544B 12 14 23:17 node_modules

  進入node_modules

  casperchenMacBookPro:node_modules casperchen$ ll

  total 0

  drwxr-xr-x 16 casperchen staff 544B 12 5 00:49 grunt

  2、可以通過 require() 來引入本地安裝的包

  直接來個例子,我們在項目根目錄下創建test.js,里面的內容很簡單

  var grunt = require('grunt');grunt.log.writeln('hello grunt');

  然后在控制臺運行test.js

  node test.js

  然后就會看到如下輸出

  casperchenMacBookPro:testUsemin casperchen$ node test.js

  hello grunt

  全局安裝

  1、將安裝包放在 /usr/local 下

  運行如下命令

  npm install -g grunt-cli

  然后進入/usr/local/bin目錄,就會發現grunt-cli已經被放置在下面了

  casperchenMacBookPro:bin casperchen$ pwd

  /usr/local/bin

  casperchenMacBookPro:bin casperchen$ ll grunt

  lrwxr-xr-x 1 root admin 39B 8 18 21:43 grunt -> ../lib/node_modules/grunt-cli/bin/grunt

  可見,全局模塊的真實安裝路徑在/usr/local/lib/node_modules/下,/usr/local/bin下的可執行文件只是軟鏈接而已

  2、可以直接在命令行里使用

  實現細節在上面其實就講到了,通過在`/usr/local/bin下創建軟鏈接的方式實現。這里不贅述

  更直觀的例子

  下面就直接看下,當我們在項目目錄下運行grunt task(task為具體的grunt任務名,自行替換)時,發生了什么事情。這里要借助node-inspector。

  首先,沒接觸過node-inspector的童鞋可以參考之前的文章了解下

  運行如下命令開啟調試

  node-inspector &

  見到如下輸出

  casperchenMacBookPro:tmp casperchen$ node-inspector &

  [1] 14390

  casperchenMacBookPro:tmp casperchen$ Node Inspector v0.6.1

  info - socket.io started

  Visit http://127.0.0.1:8080/debug?port=5858 to start debugging.

  接著,在當前任務下運行grunt任務

  ^CcasperchenMacBookPro:testUsemin casperchen$ node --debug-brk $(which grunt) dev

  debugger listening on port 5858

  接著,打開Chrome瀏覽器,輸入網址http://127.0.0.1:8080/debug?port=5858,就會自動進入斷點調試狀態。從一旁顯示的tips可以看到,全局命令grunt其實就是/usr/local/lib/node_modules/grunt-cli/bin/grunt

npm install 本地安裝與全局安裝的區別 CUOxin.COM

  按下F8接著往下跑,就會進如Gruntfile.js,此時的grunt,是本地安裝的一個node包。全局命令跟本地的包名字一樣,挺有迷惑性的。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜城市| 汤原县| 和政县| 冕宁县| 南安市| 临沂市| 芜湖市| 鲁甸县| 新余市| 兴安盟| 泗水县| 县级市| 茌平县| 堆龙德庆县| 沂源县| 岑溪市| 海城市| 尤溪县| 泸定县| 安福县| 天台县| 麻阳| 资溪县| 灵台县| 浦北县| 来凤县| 新竹市| 格尔木市| 宜兴市| 德保县| 临泉县| 长乐市| 鹤峰县| 大悟县| 岑溪市| 枣强县| 江门市| 乌鲁木齐市| 扶沟县| 巩留县| 灌南县|