麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

詳解Nodejs之npm&package.json

2019-11-19 16:20:06
字體:
來源:轉載
供稿:網友

一直以來,作為前端開發,在公司都是先寫好頁面,然后再跟后端合作,將數據填入前端頁面中,但是偶爾自己閑來無事,也會看一些框架什么的,然后利用框架做個單頁面應用啊,app什么的,這時候頁面的數據總是一些假數據,而關于數據請求的部分就沒辦法做(因為沒有后臺嘛)。所以我感覺是時候學習一下node了,這對于我以后要學的webpack,前端工程化等也有一定幫助。
作為前端,因為經常用到gulp,webpack等工具,所以我們最常見到的是npm和package.json,所以先總結一下它們倆。

npm

初始化

$ npm initor$ npm init --y 

在做前端開發的時候,我們經常會用到構建工具,例如gulp,webpack等,為了讓別人也可以參與進來,我們需要告訴別人項目有些什么依賴包,然后讓別人也安裝同樣的依賴包,而npm init產生的package.json就是用來記錄我們項目中的依賴的,同樣的,在做node開發的時候,也會用刀依賴包,同樣需要package.json記錄。

在終端輸入npm init會詢問package.json的各種信息,從而確認。如果全部使用默認值,可以直接在終端輸入npm init --y快速生成package.json。

安裝依賴包

$ npm install <package name> <package name> ...$ npm install <package name> -g$ npm install <package name> --save$ npm install <package name> --save-dev$ npm install <pacakage name> --O //--save-optional -B: --save-bundle -E: --save-exact

npm install <package name> -g 表示全局安裝,需要注意的是全局模式并不是將一個模塊安裝包安裝為一個全局包的意思,它并不意味著可以從任何地方通過require()來引用,-g的含義是將一個包安裝為全局可用的可執行命令。這意味著,所有通過-g安裝的包都可以在終端以命令方式運行,例如gulp,webpack等。

--save--save-dev的區別在于前者是生產環境中項目運行需要的依賴,安裝后被記錄在package.json中的dependencies關鍵字下;而后者是開發時候需要的依賴,安裝后被記錄在devDependencies關鍵字下。

同樣--O/B/E分別會被記錄到對應的關鍵字下。

更新依賴包

$ npm update$ npm update -g$ npm outdated$ npm outdated -g

在項目目錄下運行npm update可以升級項目中所用依賴到最新版本,而npm update -g則可以升級全局安裝的依賴包到最新版。

npm outdated用于檢查模塊是否過時并列出。

卸載依賴

$ npm uninstall <package name> <package name> ...$ npm uninstall <package name> -g$ npm uninstall <package name> --save$ npm uninstall <package name> --save-dev

使用npm uninstall可以卸載依賴,但是卸載后,在package.json中的紀錄并不會被刪除,要想在卸載依賴的同時刪除在package.json中的紀錄,需要在卸載的時候使用安裝時的所有的選項,例如,如果安裝時候使用了npm install <package name> --save則卸載的時候,同樣使用npm uninstall <pacakage name> --save,而如果使用了--save-dev,卸載時候也需要加相同的選項。

使用自定義npm命令

在package.json中,有一個scripts關鍵字,只需要在該關鍵字內寫入自定義命令以及對應執行的實際命令即可。

"scripts":{  "test": "nonde ./test.js",  "dev": "gulp --gulpfile gulpfile-dev.js",  "build": "gulp --gulpfile gulpfile-build.js"}

上面的配置中,只要我們在終端運行npm dev就是運行了gulp --gulpfile gulpfile-dev.js,這樣就省去了我們在終端輸入很長的一段命令,非常方便。

其他

npm view <pacakage name>可以查看包的package.json文件,如果只是看包的某個特性,在后面加上相應的key即可,例如npm v zepto version就是查看當前安裝的zepto的版本,v是view的簡寫。

npm ls可以分析出當前當前項目下能夠通過模塊路徑找到的所有包,并生成依賴樹。

npm doc <package name>可以打開該依賴包的官網,其實就是打開了package.json中的homepage。

package.json文件

在運行npm init后會生成package.json文件,該文件用于記錄項目中所用到的依賴以及項目的配置信息(比如名稱、版本、許可證等)。npm install命令根據這個配置文件自動下載項目運行和開發所需要的依賴。

一個比較完整的package.json文件如下:

{  "name": "project",  "version": "1.0.0",  "author": "張三",  "description": "第一個node.js程序",  "keywords":["node.js","javascript"],  "repository": {    "type": "git",    "url": "https://path/to/url"  },  "license":"MIT",  "engines": {"node": "0.10.x"},  "bugs":{"url":"http://path/to/bug","email":"[email protected]"},  "contributors":[{"name":"李四","email":"[email protected]"}],  "scripts": {    "start": "node index.js"  },  "dependencies": {    "express": "latest",    "mongoose": "~3.8.3"  },  "devDependencies": {    "grunt": "~0.4.1",    "grunt-contrib-concat": "~0.3.0"  }}

在package.json中一些關鍵字的含義:

1.name:包名

2.version:版本號

3.description:包的描述

4.homepage:包的官網url

5.autor:包的作者名字

6.contributors:包的其他貢獻者

7.dependencies:依賴包的列表,使用npm install可以安裝依賴包到node_medule目錄下

8.repository:包代碼存放的地方,可以是git或者svn

9.keywords:關鍵字

10.scripts:腳本說明對象。它主要被包管理器用來安裝、編譯、測試和卸載包,示例如下:

"scripts":{  “install”:"install.js",  "test":"test.js"}

11.main:模塊引入方法require()在引入包時,會優先檢查這個字段,并將其作為包中其余模塊的入口,如果該字段不存在,則node會檢查目錄下的index.js,index.node,index.json作為默認入口。

12.devDependencies:一些模塊只在開發時需要依賴,配置這個屬性,可以提示包的后續開發者安裝依賴包

以上就是關于node中npm和package.json的總結。希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久久成人999亚洲区美女 | 国产一区亚洲 | 色综合视频网 | 日美av在线 | 日本欧美国产 | 久久久免费观看完整版 | 日本在线观看高清完整版 | 女人叉开腿让男人桶 | 涩涩激情网 | 91网站永久免费看 | 毛片大全| 亚洲人成在线播放网站 | 羞羞漫画无遮挡观看 | 久久精品99国产国产精 | 国产一级淫片在线观看 | 免费看污视频在线观看 | 国产在线观看91精品 | 国产精品久久国产精品 | 欧美成人精品一区二区 | 久久嗨 | 久久久久一区二区三区 | 欧美a∨一区二区三区久久黄 | 久久国产成人午夜av浪潮 | 最新欧美精品一区二区三区 | 99re热视频这里只精品 | 成人在线观看一区二区三区 | 亚洲一级毛片 | 国产一区网址 | av在线浏览 | 色综合久久久久久久久久久 | 黄污在线看 | 91懂色| 亚洲人成电影在线 | 中文字幕精品在线观看 | 午夜视频在线免费观看 | gogo全球大胆高清人露出91 | 欧美不卡在线 | 欧美一级片 在线播放 | www.91成人 | 美女羞羞视频网站 | 亚洲日色|