摘要:另一方面,這樣做也無法支持不同項(xiàng)目使用不同版本的。我們可以換一個(gè)源,即把服務(wù)器換到國(guó)內(nèi),例如淘寶的源運(yùn)行下面的命令即可切換淘寶源的配置被存儲(chǔ)在,你可以隨時(shí)改。安裝方法使用方法切換源等見鏈接
Nodejs生態(tài)圈很強(qiáng)大,第一個(gè)原因就是NPM,因?yàn)槿蛴袩o數(shù)的程序員在NPM中貢獻(xiàn)了自己的力量。
為了避免造輪子,我們有時(shí)候會(huì)用到其他人的勞動(dòng)成果,比如一些優(yōu)秀的框架,比如Express,我們直接使用NPM下載下來就可以用了,降低開發(fā)成本和時(shí)間。
安裝安裝好nodejs后就安裝好了npm,這時(shí)系統(tǒng)自帶npm命令
如何使用以為Express來舉例。
npm 的官網(wǎng)可以找到 npm 包。
https://www.npmjs.com/
例如搜索Express,就會(huì)告訴你安裝方法和使用方法:
新建一個(gè)文件夾,然后運(yùn)行:
npm init初始化,一直按回車,它會(huì)自動(dòng)生成package.json 文件,這個(gè)后面再說這個(gè)文件的作用。
然后
npm install express安裝
會(huì)出現(xiàn)node_modules文件夾
node_modules文件夾就是所有包安裝的位置。
express已經(jīng)安裝到了node_modules文件夾,其他的很多文件都是這個(gè)express依賴的包
我們寫一個(gè)項(xiàng)目的時(shí)候可能會(huì)用到很多很多包,這些包可能是一些工具,也可能是框架。我們每使用一個(gè)包,就會(huì)把這些包下載下來,然后他會(huì)放到node_modules目錄中。
那么項(xiàng)目如果太大,哪些包安裝了哪些沒安裝,我們?nèi)绾沃滥??有沒有一個(gè)機(jī)制來記住我們安裝的包呢?
有,nodejs提供了一個(gè)機(jī)制叫package.json。
他是一個(gè)文件,他可以記住所有安裝的包的信息,包括名稱、版本信息。
如果我們遷移項(xiàng)目,我們就能夠知道安裝了什么包。因?yàn)閚ode_modules目錄中文件比較大,而且不放在版本控制中(github等),也不是源碼的一部分,我們只要知道node_modules里安裝的一些包的名字就可以了,根本不需要這個(gè)目錄的內(nèi)容。
比如說現(xiàn)在一個(gè)同事得到了這一份代碼,那么這個(gè)node_modules目錄中的代碼他是不需要的。因?yàn)樗恍枰惭b過得這些包的名稱就可以了,到他自己的電腦上再安裝就可以了。
package.json就是記錄所有安裝的包的信息的文件。
生成方法運(yùn)行npm init初始化一個(gè)項(xiàng)目。
他會(huì)讓你回答一些關(guān)于這個(gè)項(xiàng)目的信息,一直按回車,因?yàn)檫@些信息后面可以改,最開始使用默認(rèn)的就好。
然后就會(huì)生成一個(gè)package.json的文件。
舉例:嘗試安裝Express并查看package.jsonnpm install --save express
安裝之后出現(xiàn)很多包,這些都是express依賴的包。
"dependencies"安裝后出dependencies字段會(huì)出現(xiàn)安裝的包的詳細(xì)信息,包括包的名稱和版本號(hào)。
"dependencies"中文是依賴的意思。
devDependencies是開發(fā)環(huán)境依賴的意思。例如我們用下面的命令行安裝gulp
npm install --save-dev gulp
開發(fā)環(huán)境的包會(huì)記錄在這里
使用--save-dev就是開發(fā)環(huán)境依賴的一些包,會(huì)記錄到devDependencies
在"scripts"里加入一行"start": "node app.js",
"scripts": { "test": "echo "Error: no test specified" && exit 1", "start": "node app.js" },
那么如果我們運(yùn)行npm run start
就會(huì)運(yùn)行"start"里面的命令。
作用:別人下載你的代碼之后可能不知道怎么運(yùn)行你的項(xiàng)目,那么你把這些命令寫在start里,那么項(xiàng)目入口文件之類的就一目了然。
使用package.json 命令:npm installpackage.json記錄了安裝包的所有安裝信息,那么別人得到這些信息如何把這些包安裝下來呢(安裝到他的本地)
使用命令npm install就可以了,比如我們現(xiàn)在刪掉node_modules,然后再運(yùn)行npm install
他就會(huì)重新安裝
"dependencies": { "express": "^4.16.4" }, "devDependencies": { "gulp": "^3.9.1" }
這兩個(gè)依賴中的包
全局安裝與局部安裝的區(qū)別 全局安裝比如我們安裝webpack
npm install -g webpack
-g 意思是Global,全局的意思,他會(huì)把webpack作為一個(gè)命令,一個(gè)可執(zhí)行文件,安裝到我們的系統(tǒng)中,以后我們就可以使用這個(gè)命令了
局部安裝只安裝到這個(gè)項(xiàng)目當(dāng)前的文件夾中,如果想使用webpack命令,就要運(yùn)行使用當(dāng)前項(xiàng)目下的文件,才能運(yùn)行webpack
node_modules/.bin/webpack
用Babel舉例說明全局安裝與局部安裝的區(qū)別:
命令行轉(zhuǎn)碼babel-cli————阮一峰的es6教程
上面代碼是在全局環(huán)境下,進(jìn)行 Babel 轉(zhuǎn)碼。這意味著,如果項(xiàng)目要運(yùn)行,全局環(huán)境必須有Babel,也就是說項(xiàng)目產(chǎn)生了對(duì)環(huán)境的依賴。另一方面,這樣做也無法支持不同項(xiàng)目使用不同版本的 Babel。一個(gè)解決辦法是將babel-cli安裝在項(xiàng)目之中。
總結(jié):全局安裝的話你的項(xiàng)目不容易更新,因?yàn)椴煌?xiàng)目使用的babel的版本可能不同,而且你和你團(tuán)隊(duì)使用的babel的版本也可能不同。所以要把babel直接安裝在項(xiàng)目中。這樣其他人拿到項(xiàng)目再安裝項(xiàng)目?jī)?nèi)的babel,就不會(huì)出現(xiàn)版本不兼容問題了。
http-server舉例說明再比如我們安裝http-server
npm install -g http-server
安裝在了這個(gè)目錄下新增的一個(gè)文件,叫做http-server
npm install -g的時(shí)候安裝在全局目錄下,npm install不帶-g的時(shí)候安裝在當(dāng)前目錄下,如圖
如果是全局安裝,那么直接就可以用了,因?yàn)镸ac中 /usr/local/bin 是包含在path里面的。
如果我直接在命令行里輸入http-server,那么會(huì)訪問到/usr/local/bin這個(gè)路徑里的http-server文件
如果只安裝在了局部的項(xiàng)目里,想用的話就去當(dāng)前目錄下去找http-server這個(gè)文件,一樣可以用:
命令行的實(shí)質(zhì)就是一個(gè)文件而已!全局命令就是裝在環(huán)境里的文件!局部命令就是放在一個(gè)目錄里,用的時(shí)候需要執(zhí)行局部文件!
注意:在國(guó)內(nèi)安裝這些包的時(shí)候有時(shí)候會(huì)很慢,因?yàn)檫@些包的服務(wù)器在國(guó)外。我們可以換一個(gè)源,即把服務(wù)器換到國(guó)內(nèi),例如淘寶的源
運(yùn)行下面的命令即可切換淘寶源
npm config set registry https://registry.npm.taobao.org/ npm config set loglevel http npm config set progress false
npm 的配置被存儲(chǔ)在 ~/.npmrc,你可以隨時(shí)改。
這是官方網(wǎng)站
https://npm.taobao.org/
安裝node-sass的正確姿勢(shì)
從 npm 到全面擁抱 yarn從 npm 到全面擁抱 yarn
個(gè)人覺得 yarn 有以下好處:
超快的下載速度。
離線下載,如果你懂 ruby,這個(gè)有點(diǎn)像 bundle,就是之前下載過一次,這個(gè)包就會(huì)放到電腦上的一個(gè)地方,下次別的項(xiàng)目要使用同一個(gè)包的時(shí)候就不用下載了,而是做一個(gè)鏈接,這樣速度超級(jí)快,這一點(diǎn)很重要,npm 飽受詬病的一點(diǎn)就是,每次安裝依賴,都需要從網(wǎng)絡(luò)下載一大堆東西,而且是全部重新下載。工程多的時(shí)候比較煩人。這下子可以節(jié)約大量時(shí)間了。
擁有 lockfile 文件,在 yarn 中叫 yarn.lock,這個(gè)在新版的 npm 也有這個(gè)功能,它的文件名叫 package-lock.json,這個(gè)文件會(huì)記錄每次安裝的包的版本的精確信息,這樣,每次運(yùn)行 yarn install 就會(huì)得到一模一樣的依賴環(huán)境,而不是會(huì)出現(xiàn)個(gè)別包的版本不同,從而引發(fā)環(huán)境問題導(dǎo)致項(xiàng)目運(yùn)行情況不同的尷尬事件。
安裝方法、使用方法、切換源等見鏈接
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/98644.html
摘要:使用淘寶鏡像大家都知道國(guó)內(nèi)直接使用的官方鏡像是非常慢的,這里推薦使用淘寶鏡像。淘寶鏡像是一個(gè)完整鏡像,你可以用此代替官方版本只讀,同步頻率目前為分鐘一次以保證盡量與官方服務(wù)同步。 npm 使用介紹 NPM是隨同NodeJS一起安裝的包管理工具,能解決NodeJS代碼部署上的很多問題,常見的使用場(chǎng)景有以下幾種: 允許用戶從NPM服務(wù)器下載別人編寫的第三方包到本地使用。 允許用戶從NPM...
摘要:但這并不意味著依賴版本是鎖死的。黃色表示不符合指定的語(yǔ)義化版本范圍,比如大版本升級(jí),升級(jí)可能會(huì)遇到兼容性問題。文件可以列出不想打包的文件,避免把一些無關(guān)的文件發(fā)布到上。 作者: LeanCloud weakish 分享一些 npm 包管理工具的實(shí)用小竅門,希望能夠略微提高下前端、Node.js 開發(fā)者的生活質(zhì)量。 絕大多數(shù)前端和 Node.js 開發(fā)者每天的日常工作都離不開 npm,不...
摘要:使用介紹是隨同一起安裝的包管理工具,能解決代碼部署上的很多問題,常見的使用場(chǎng)景有以下幾種允許用戶從服務(wù)器下載別人編寫的第三方包到本地使用。允許用戶將自己編寫的包或命令行程序上傳到服務(wù)器供別人使用。 NPM 使用介紹 NPM是隨同NodeJS一起安裝的包管理工具,能解決NodeJS代碼部署上的很多問題,常見的使用場(chǎng)景有以下幾種: 允許用戶從NPM服務(wù)器下載別人編寫的第三方包到本地使用。...
摘要:常見問題的中的和會(huì)匹配最近的小版本依賴包,比如會(huì)匹配所有版本,但是不包括會(huì)匹配最新的大版本依賴包,比如會(huì)匹配所有的包,包括,但是不包括你也有可能會(huì)看見在中模塊的版本號(hào)前面既沒有也沒有就像下面那樣上面的情況屬于精確安裝模塊指定的版本號(hào)。 常見問題 1.npm 的package.json中的~和^ ~會(huì)匹配最近的小版本依賴包,比如~1.2.3會(huì)匹配所有1.2.x版本,但是不包括1.3.0...
摘要:無需手動(dòng)拷貝文件或者創(chuàng)建軟鏈接到目錄,有更優(yōu)雅的解決方案。這是因?yàn)樽R(shí)別協(xié)議的,得知這個(gè)包需要直接從文件系統(tǒng)中獲取,會(huì)自動(dòng)創(chuàng)建軟鏈接到中,完成安裝過程。 nodejs 社區(qū)乃至 Web 前端工程化領(lǐng)域發(fā)展到今天,作為 node 自帶的包管理工具的 npm 已經(jīng)成為每個(gè)前端開發(fā)者必備的工具。但是現(xiàn)實(shí)狀況是,我們很多人對(duì)這個(gè)nodejs基礎(chǔ)設(shè)施的使用和了解還停留在: 會(huì)用 npm insta...
摘要:由于文件中版本號(hào)的特點(diǎn),下面三個(gè)版本號(hào)在安裝的時(shí)候代表不同的含義。安裝版本統(tǒng)一為了防止拉取到不同的版本,有一個(gè)鎖定文件記錄了被確切安裝上的模塊的版本號(hào)。 showImg(https://segmentfault.com/img/bVbs8Rg?w=1920&h=1080); 一位用不好包管理器的前端,是一個(gè)入門級(jí)前端,一個(gè)用不好webpack的前端,是一個(gè)初級(jí)前端 三個(gè)包管理器是可以一...
閱讀 1917·2021-11-25 09:43
閱讀 1422·2021-11-22 14:56
閱讀 3288·2021-11-22 09:34
閱讀 2026·2021-11-15 11:37
閱讀 2281·2021-09-01 10:46
閱讀 1408·2019-08-30 15:44
閱讀 2304·2019-08-30 13:15
閱讀 2403·2019-08-29 13:07