日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

npm包全局安装和局部安装,执行包命令有什么不同?

發布時間:2025/3/21 69 豆豆
生活随笔 收集整理的這篇文章主要介紹了 npm包全局安装和局部安装,执行包命令有什么不同? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

之前開發了一個npm的包。在實際應用中發現了一個問題。如果你想要直接執行這個包的命令,那么你就需要全局安裝這個包。如果你只是局部安裝,且沒有在package.json文件中配置的話,就會提示該命令無法找到。這是為什么呢?今天就來為大家介紹一下全局安裝和局部安裝到底是做了什么,

全局安裝

安裝位置

全局安裝是將npm包安裝在你的node安裝目錄下的node_modules文件夾中。在windows和mac中,全局安裝的默認路徑是不同的。在mac中默認是安裝到/usr/locla/lib中。當然你也可以通過一下命令來查看全局安裝路徑。

// 查看全局安裝路徑 npm root -g// 查看npm的基礎設置 npm config ls// 查看安裝目錄路徑 npm config get prefix 復制代碼

如果是公共電腦你不想將npm包安裝在默認目錄下,那么你可以通過命令來修改安裝路徑。

// 修改安裝目錄路徑 npm config set '' 復制代碼

如果在全局安裝中遇到權限問題報錯,你需要修改文件夾的權限,執行一下命令。

sudo chown -R $(whoami) $(npm config get prefix)/{lib/node_modules,bin,share} 復制代碼

全局命令

npm包在全局安裝之后,這個包的命令就會被注冊到全局,你就可以直接在命令行中執行這個命令了。其實當你全局安裝一個npm包之后,這個包被存放在/usr/locla/lib/node_modules下。而在這個包的package.json文件中,在bin屬性下配置的執行命令,會放在/usr/locla/bin文件中。當你在命令行執行這個命令,系統就會執行/usr/locla/bin目錄下對應的文件。

安裝過程

以全局安裝vue-cli為例,為大家簡述一下安裝過程。

  • npm install -g @vue/cli 安裝vue包到/usr/locla/lib/node_modules。
  • 2. 查找vue包的package.json中的bin屬性。

    3. 將vue命令的執行文件添加到/usr/locla/bin中。

    4. 在命令行中執行vue create vue-test,命令被識別。

    本地安裝

    安裝位置

    在特定項目中執行npm install xxx,那么這個包會被安裝在這個項目的node_moduels目錄下。但是如果你在這個項目中直接執行包中的命令,就會發現控制臺報錯,告訴你這個命令找不到。這時候有兩個解決方法:

  • 使用npx執行:npx出現主要解決的問題就是調用項目內部安裝的模塊,所以你可以在項目中執行npx 包命令。
  • 在package.json文件中配置:
  • "scripts": {"包命令": "包命令", } 復制代碼

    原理: 在本地安裝一個包之后,這個包的命令會被添加到項目的node_modules/.bin文件中。執行npm run 命令,package.json中的scripts會按照一定順序尋找對應命令的位置,本地的node_modules/.bin也在尋找的清單中。所以本地安裝的包的命令可以執行。

    轉載于:https://juejin.im/post/5ccf9dc0f265da03914d7524

    《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

    總結

    以上是生活随笔為你收集整理的npm包全局安装和局部安装,执行包命令有什么不同?的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。