【轉發】如何使用NPM?CNPM又是什麼?

来源:https://www.cnblogs.com/laocainiao160622/archive/2019/03/27/10608044.html
-Advertisement-
Play Games

轉發:https://www.jianshu.com/p/f581cf9360a2 背景介紹 什麼是npm? npm(node package manager)是nodejs的包管理器,用於node插件管理(包括安裝、卸載、管理依賴等), NPM是隨同NodeJS一起安裝的包管理工具,能解決Node ...


轉發:https://www.jianshu.com/p/f581cf9360a2

背景介紹

 什麼是npm?

npm(node package manager)是nodejs的包管理器,用於node插件管理(包括安裝、卸載、管理依賴等), NPM是隨同NodeJS一起安裝的包管理工具,能解決NodeJS代碼部署上的很多問題,它是 Node 獲得成功的重要原因之一。常見的使用場景有以下幾種:

允許用戶從NPM伺服器下載別人編寫的第三方包到本地使用。

允許用戶從NPM伺服器下載並安裝別人編寫的命令行程式到本地使用。

允許用戶將自己編寫的包或命令行程式上傳到NPM伺服器供別人使用。

由於新版的nodejs已經集成了npm,所以之前npm也一併安裝好了。同樣可以通過輸入 "npm -v" 來測試是否成功安裝

為啥我們需要一個包管理工具呢?因為我們在Node.js上開發時,會用到很多別人寫的JavaScript代碼。如果我們要使用別人寫的某個包,每次都根據名稱搜索一下官方網站,下載代碼,解壓,再使用,非常繁瑣。於是一個集中管理的工具應運而生:大家都把自己開發的模塊打包後放到npm官網上,如果要使用,直接通過npm安裝就可以直接用,不用管代碼存在哪,應該從哪下載。

更重要的是,如果我們要使用模塊A,而模塊A又依賴於模塊B,模塊B又依賴於模塊X和模塊Y,npm可以根據依賴關係,把所有依賴的包都下載下來並管理起來。否則,靠我們自己手動管理,肯定既麻煩又容易出錯。

什麼是cnpm?

因為npm安裝插件是從國外伺服器下載,受網路影響大,可能出現異常,所以我們樂於分享的淘寶團隊幹了這事。來自官網:“這是一個完整 npmjs.org 鏡像,你可以用此代替官方版本(只讀),同步頻率目前為 10分鐘 一次以保證儘量與官方服務同步。”

知識剖析

npm install moduleNames:安裝Node模塊

安裝完畢後會產生一個node_modules目錄,其目錄下就是安裝的各個node模塊。

node的安裝分為全局模式和本地模式。

一般情況下會以本地模式運行,包會被安裝到和你的應用程式代碼的本地node_modules目錄下。

在全局模式下,Node包會被安裝到Node的安裝目錄下的node_modules下

為什麼要保存至PACKAGE.JSON?

因為node插件包非常大,版本龐雜,所以不加入package信息,模塊間的依賴變得非常困難,將配置信息寫入package.json並將其加入版本管理,其他開發者對應下載即可(命令提示符執行npm install,則會根據package.json下載所有需要的包)。 每個項目的根目錄下麵,一般都有一個package.json文件,定義了這個項目所需要的各種模塊,以及項目的配置信息(比如名稱、版本、許可證等元數據)。npm install 命令根據這個配置文件,自動下載所需的模塊,也就是配置項目所需的運行和開發環境。

PACKAGE.JSON 屬性說明:

name - 包名。(不要把node或者js放在名字中)

version - 包的版本號。

dependencies - 項目運行所依賴的模塊

devDependencies - 項目開發所需要的模塊

bin - 這需要在你的package.json中提供一個bin欄位,它是一個命令名和本地文件名的映射。在安裝時,如果是全局安裝,npm將會使用符號鏈接把這些文件鏈接到prefix/bin,如果是本地安裝,會鏈接到./node_modules/.bin/

npm常用命名

使用npm卸載插件:npm uninstall < name > [-g] [--save-dev] PS:不要直接刪除本地插件包

使用npm更新插件:npm update < name > [-g] [--save-dev] 

更新全部插件:npm update [--save-dev] 

查看npm幫助:npm help 

查看當前目錄已安裝插件:npm list 

還有一些npm的簡單命令就不多說了

PS:npm安裝插件過程:從http://registry.npmjs.org下載對應的插件包(該網站伺服器位於國外,所以經常下載緩慢或出現異常),解決辦法就是cnpm

CNPM介紹:

官方網址:http://npm.taobao.org

安裝:命令提示符執行npm install cnpm -g --registry=https://registry.npm.taobao.org

註意:安裝完後最好查看其版本號cnpm -v或關閉命令提示符重新打開,安裝完直接使用有可能會出現錯誤 

PS:cnpm跟npm用法完全一致,只是在執行命令時將npm改為cnpm。

3.常見問題

bower 和 npm有什麼區別

4.解決方案

npm 是伴隨 Node.js 出現的一個包管理器,最開始只能支持 Node.js 的模塊管理,但是後來, npm 官網經過一次改版,打出的口號是,javascript 的包管理器,所以,其已經不在局限於是 Node.js 的模塊管理了,已經通用到了所有 js 的包管理工具了,可以說,前後通吃了。

bower 的話,從一開始,就是專門為前端表現設計的包管理器,一切全部為前端考慮的。npm 和 bower 的最大區別,就是 npm 支持嵌套地依賴管理,而 bower只能支持扁平的依賴(嵌套的依賴,由 程式員自己解決)。

嵌套依賴,指的就是,你依賴的軟體包,還有它自己的依賴,好像摘葡萄,一摘一大串。在伺服器環境的時候,這並沒什麼關係,因為存儲空間夠大,一切代碼都是本地運行,只要解決完依賴就行了, 但是到了用戶產品的瀏覽器里,就很成問題了,你不能讓用戶去下載好幾M的js代碼,那就太糟糕了。在這個情況下,就需要程式員自己手動解決用到的類庫的嵌套依賴問題。比如確保各種各樣的插件 都依賴同一個版本的jQuery。

擴展思考

cnpm有哪些問題?

1.cnpm 的倉庫只是 npm 倉庫的一個拷貝,它不承擔 publish 工作,所以你用 cnpm publish 命令會執行失敗的

2.不僅是 publish 會執行失敗,其它的需要註冊用戶(npm adduser)、或者修改 package 狀態等命令都無法用 cnpm

7.參考文獻

npm 模塊安裝機制簡介

開發者對 npm 公司不滿,unpublish 了自己的所有模塊

npm的一些常用命令

bower 和 npm 的區別詳細介紹

更多提問

Q:全局安裝和本地安裝的區別?

因為全局模式安裝,包可以供所有的程式使用。本地安裝則不可以。 npm 預設會把包安裝到當前目錄下。這反映了 npm 不同的設計哲學。如 果把包安裝到全局,可以提高程式的重覆利用程度,避免同樣的內容的多 份副本,但壞處是難以處理不同的版本依賴。如果把包安裝到當前目錄, 或者說本地,則不會有不同程式依賴不同版本的包的衝突問題,同時還減 輕了包作者的 API 相容性壓力,但缺陷則是同一個包可能會被安裝許多次。

Q:為什麼進行了全局安裝還要進行本地安裝

1、在js實例代碼中,預設下node.js會在NODE_PATH和目前js所在項目下的node_modules文件夾下去尋找模塊,因此,如果只是全局安裝,不能直接通過require()的方式去引用模塊,需要手動解決包路徑的配置問題,當然你也可以複製全局安裝的node_modules文件夾到項目下,還有辦法可以選擇將環境變數的NODE_PATH設置為C:\Program Files\nodejs。

 2.對於包的更新不好管理,可能你需要為每個包重新命名,如[email protected][email protected]...,為了區別不同項目使用指定的包,保證模塊之間的相互依賴,區別每個項目正常運行

Q:如何在package.JSON的dependencies和devDependencies寫入信息

A:npm install --save babel-cli和npm install -dev babel-cli使用這兩個命令安裝後可自動寫入文件

npm install --save-dev babel-cli也可以在一起用



作者:沒事兒啊
鏈接:https://www.jianshu.com/p/f581cf9360a2
來源:簡書
簡書著作權歸作者所有,任何形式的轉載都請聯繫作者獲得授權並註明出處。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • angular.js AngularJS [1] 誕生於2009年,由Misko Hevery 等人創建,後為Google所收購。是一款優秀的前端JS框架,已經被用於Google的多款產品當中。AngularJS有著諸多特性,最為核心的是:MVC(Model–view–controller)、模塊化 ...
  • 這是一個非常老牌的Bootstrap商業模板,全面性和穩定性俱佳 ...
  • JavaScript中的閉包 JavaScript中的閉包 介紹 在大多數常用語言中,函數返回後,所有局部變數不再可訪問,因為堆棧幀已被銷毀。牢記這一點,閉包可以被看作是當函數返回時不會釋放的棧幀。 為什麼使用閉包 我有很多人問我為什麼要關閉。我會儘力解釋。 我遇到過閉包的場景是使用Tabular ...
  • 什麼是事件冒泡 <div style="width: 200px;height: 200px;background: red;margin: 200px auto;" onclick="box()"> <p onclick="test()" style="background: blue"> wub ...
  • 1.無限滾動的運用場景: 一般運用在列表展示,有分頁、下拉載入更多的需求中。 2.代碼分析 代碼很簡單,實現了列表分頁,數據載入完之後顯示數據狀態 參考mint-ui官網介紹 1.為HTML元素添加v-infinite-scroll指令即可使用無限滾動。 2.滾動該元素,當其底部與被滾動元素底部的距 ...
  • 這裡先放上官網的教程和說明:點擊這裡,vue導航守衛官方文檔 路由守衛 路由守衛說白了就是路由攔截,在地址欄跳轉之前 之後 跳轉的瞬間 乾什麼事 全局守衛 全局守衛顧名思義,就是全局的,整個項目所有路由,跳轉所用到的守衛(攔截),設置了全局守衛之後,只要路由(瀏覽器地址欄)發生變化就會觸發的事件 全 ...
  • [toc] 1. 搭建環境 2. React知識點 1. 組件 組件:就是將整個UI拆分為很多小的,可重用的UI,每一個小的UI獨立做自己的事情。 1.1 定義一個組件 一個組件需要繼承 重寫 函數,返回 註意點: 1.只要有JSX的地方必須引入 2.返回值中只能有一個元素包裹, 包裹整個JSX,如 ...
  • 該文章用於督促自己學習TypeScript,作為學筆記進行保存,如果有錯誤的地方歡迎指正 2019-03-27 16:50:03 一、什麼是TypeScript? TypeScript是javascript的超集,在ts中可以使用所有的js代碼,並對js進行了擴展,包括類型效驗,數據類型,介面等 如 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...