實(shí)例解析package.json和最常見(jiàn)的scripts字段
一個(gè)切圖仔的自我救贖
我的開(kāi)源工具庫(kù):mdollar
之后準(zhǔn)備學(xué)習(xí):unocss、瀏覽器的垃圾回收機(jī)制(v8)
前言
日常開(kāi)發(fā)中,現(xiàn)在的前端開(kāi)發(fā)已經(jīng)被三大框架取代,其中最主流的不過(guò)vue和react,而開(kāi)發(fā)這些項(xiàng)目的時(shí)候不得不接觸package.json這個(gè)文件,可你真的了解這個(gè)文件嗎?
什么是package.json
package.json文件是一個(gè)JSON格式的文件,它包含了Node.js項(xiàng)目的元數(shù)據(jù)和依賴(lài)信息。它是Node.js系統(tǒng)的核心,也是npm的配置文件。有了package.json文件,你可以方便地管理和安裝你的項(xiàng)目需要的外部模塊,以及定義一些可以在命令行中運(yùn)行的腳本。package.json文件還可以讓你的項(xiàng)目更容易被其他開(kāi)發(fā)者發(fā)現(xiàn)和使用,因?yàn)樗峁┝四愕捻?xiàng)目的名稱(chēng),描述,作者,許可證等信息。
詳解package.json文件結(jié)構(gòu)
package.json文件是一個(gè)由鍵值對(duì)組成的對(duì)象,每個(gè)鍵值對(duì)都有一個(gè)特定的含義和作用。下面是一個(gè)package.json文件的示例:
{
"name": "my-project",
"version": "1.0.0",
"description": "一個(gè)測(cè)試項(xiàng)目",
"main": "index.js",
"scripts": {
"start": "node index.js",
"test": "mocha"
},
"dependencies": {
"lodash": "^4.17.21"
},
"devDependencies": {
"mocha": "^9.1.3"
},
"author": "作者名字 <email@example.com>",
"license": "MIT",
"homepage": "https://example.com/my-project",
"bugs": {
"url": "https://github.com/myname/my-project/issues"
},
"repository": {
"type": "git",
"url": "https://github.com/myname/my-project.git"
}
}- name: 這是你的包的名字,必須是小寫(xiě)的,且只能包含一個(gè)單詞,可以包含連字符和下劃線。如果你打算發(fā)布你的包,這個(gè)字段是必需的,因?yàn)樗蛌ersion字段一起構(gòu)成了一個(gè)唯一的標(biāo)識(shí)符。
- version: 這是你的包的版本號(hào),必須符合語(yǔ)義化版本規(guī)范,即x.x.x的形式。如果你打算發(fā)布你的包,這個(gè)字段也是必需的,因?yàn)樗蚽ame字段一起構(gòu)成了一個(gè)唯一的標(biāo)識(shí)符。如果你不打算發(fā)布你的包,這兩個(gè)字段都是可選的。
- description: 這是你的包的簡(jiǎn)介,是一個(gè)字符串。這個(gè)字段可以幫助他人在npm搜索中發(fā)現(xiàn)你的包。
- main: 這是你的包的入口文件,通常是index.js。當(dāng)別人使用require()函數(shù)引入你的包時(shí),這個(gè)文件會(huì)被加載。
- scripts: 這是一個(gè)對(duì)象,用來(lái)定義一些可以通過(guò)npm run命令執(zhí)行的腳本。比如,start腳本定義了如何啟動(dòng)你的包,test腳本定義了如何測(cè)試你的包。
- dependencies: 這是一個(gè)對(duì)象,用來(lái)列出你的包所依賴(lài)的其他包及其版本范圍。當(dāng)你安裝或發(fā)布你的包時(shí),這些依賴(lài)會(huì)被自動(dòng)安裝。比如,lodash是一個(gè)常用的工具庫(kù),你可以指定它的版本范圍為^4.17.21,表示安裝大于等于4.17.21且小于5.0.0的最新版本。
- devDependencies: 這也是一個(gè)對(duì)象,用來(lái)列出你的包在開(kāi)發(fā)或測(cè)試時(shí)所依賴(lài)的其他包及其版本范圍。這些依賴(lài)只會(huì)在開(kāi)發(fā)環(huán)境中被安裝,不會(huì)影響生產(chǎn)環(huán)境。比如,mocha是一個(gè)常用的測(cè)試框架,你可以指定它的版本范圍為^9.1.3。
- author: 這是你的包的作者信息,可以是一個(gè)字符串或一個(gè)對(duì)象。如果是一個(gè)字符串,通常包含作者的名字和郵箱地址。如果是一個(gè)對(duì)象,可以包含name, email, url等字段。
- license: 這是你的包使用的許可證類(lèi)型,通常是一個(gè)字符串。比如,MIT表示使用MIT許可證。
- homepage: 這是你的包的項(xiàng)目主頁(yè)地址,通常是一個(gè)字符串。比如,https://example.com/my-project表示項(xiàng)目主頁(yè)在example.com上。
- bugs: 這是你的包的問(wèn)題追蹤器地址或者報(bào)告問(wèn)題的郵箱地址,可以是一個(gè)字符串或一個(gè)對(duì)象。如果是一個(gè)字符串,通常表示問(wèn)題追蹤器地址。如果是一個(gè)對(duì)象,可以包含url和email兩個(gè)字段。
- repository: 這是你的包所在的代碼倉(cāng)庫(kù)地址和類(lèi)型,通常是一個(gè)對(duì)象??梢园瑃ype和url兩個(gè)字段。type表示倉(cāng)庫(kù)類(lèi)型,比如git。url表示倉(cāng)庫(kù)地址,比如https://github.com/myname/my-project.git。
scripts詳解
scripts可能就是我們接觸過(guò)最多的一個(gè)字段了,我們來(lái)詳細(xì)說(shuō)說(shuō)scripts這個(gè)字段,scripts字段是一個(gè)對(duì)象,它的每個(gè)屬性都是一個(gè)腳本命令的名稱(chēng),對(duì)應(yīng)的值是要執(zhí)行的命令。例如:
{
"scripts": {
"build": "node build.js",
"test": "mocha test/*.js",
"start": "node index.js"
}
}這里定義了三個(gè)腳本命令:build、test和start。我們可以通過(guò)npm run build來(lái)執(zhí)行node build.js,通過(guò)npm run test來(lái)執(zhí)行mocha test/*.js,通過(guò)npm run start來(lái)執(zhí)行node index.js。
注意,npm run會(huì)把當(dāng)前項(xiàng)目下的node_modules/.bin目錄加入到PATH環(huán)境變量中,所以我們可以直接使用本地安裝的模塊的命令,而不需要指定完整的路徑。比如上面的例子中,我們可以直接使用mocha而不需要寫(xiě)成node_modules/.bin/mocha。
scripts字段有哪些特殊的腳本命令
除了我們自定義的腳本命令外,scripts字段還支持一些特殊的腳本命令,它們會(huì)在特定的情況下自動(dòng)執(zhí)行。這些特殊的腳本命令有:
- start:當(dāng)我們直接運(yùn)行npm start時(shí),會(huì)執(zhí)行這個(gè)腳本命令。通常用來(lái)啟動(dòng)項(xiàng)目。
- test:當(dāng)我們直接運(yùn)行npm test時(shí),會(huì)執(zhí)行這個(gè)腳本命令。通常用來(lái)運(yùn)行測(cè)試。
- install:當(dāng)我們?cè)诋?dāng)前項(xiàng)目下運(yùn)行npm install時(shí),會(huì)在安裝完成后執(zhí)行這個(gè)腳本命令。通常用來(lái)做一些安裝后的初始化操作。
- uninstall:當(dāng)我們?cè)诋?dāng)前項(xiàng)目下運(yùn)行npm uninstall時(shí),會(huì)在卸載完成后執(zhí)行這個(gè)腳本命令。通常用來(lái)做一些卸載后的清理操作。
- publish:當(dāng)我們?cè)诋?dāng)前項(xiàng)目下運(yùn)行npm publish時(shí),會(huì)在發(fā)布前執(zhí)行這個(gè)腳本命令。通常用來(lái)做一些發(fā)布前的檢查或準(zhǔn)備工作。
- prexxx和postxxx:當(dāng)我們運(yùn)行任意一個(gè)腳本命令時(shí),如果存在與之對(duì)應(yīng)的prexxx或postxxx腳本命令(xxx是任意名稱(chēng)),則會(huì)在該腳本命令之前或之后執(zhí)行prexxx或postxxx腳本命令。通常用來(lái)做一些前置或后置的操作
使用scripts字段有以下幾個(gè)好處:
- 可以簡(jiǎn)化一些復(fù)雜的命令,比如我們可以用npm run build來(lái)代替node build.js --env production --minify --sourcemap等等。
- 可以統(tǒng)一不同的操作系統(tǒng)和環(huán)境下的命令,比如我們可以用npm run clean來(lái)代替rm -rf dist或del /s /q dist等等。
- 可以利用npm提供的一些變量和參數(shù),比如我們可以用npm_package_name來(lái)獲取package.json中的name字段的值,或者用npm_config_xxx來(lái)獲取npm配置中的xxx字段的值。
- 可以方便地調(diào)用其他腳本命令,比如我們可以用npm run xxx來(lái)調(diào)用scripts字段中定義的xxx腳本命令,或者用npm explore – npm run xxx來(lái)調(diào)用依賴(lài)包中定義的xxx腳本命令。
scripts字段有哪些注意事項(xiàng)
使用scripts字段時(shí),還有以下幾個(gè)注意事項(xiàng):
- 如果腳本命令中包含空格或特殊字符,需要用雙引號(hào)或單引號(hào)括起來(lái),比如"echo “Hello World”"或’echo “Hello World”'。
- 如果腳本命令中需要使用多個(gè)命令,需要用&&或||連接,比如"echo “Hello” && echo “World”“或"echo “Hello” || echo “World””。
- 如果腳本命令中需要使用環(huán)境變量,需要用$或%引用,比如"echo $PATH"或"echo %PATH%"。
- 如果腳本命令中需要使用注釋?zhuān)枰?或//開(kāi)頭,比如"# this is a comment"或"// this is a comment"。
scripts字段有哪些實(shí)例
最后,我們來(lái)看幾個(gè)scripts字段的實(shí)例,希望能給大家一些啟發(fā)和參考。
實(shí)例一:使用scripts字段來(lái)編譯和打包項(xiàng)目
假設(shè)我們有一個(gè)使用TypeScript和Webpack開(kāi)發(fā)的項(xiàng)目,我們可以在scripts字段中定義以下幾個(gè)腳本命令:
{
"scripts": {
"build": "npm run clean && npm run compile && npm run bundle",
"clean": "rimraf dist",
"compile": "tsc",
"bundle": "webpack"
}
}這樣,我們就可以通過(guò)npm run build來(lái)一鍵編譯和打包我們的項(xiàng)目。其中:
- build是一個(gè)組合型的腳本命令,它會(huì)依次執(zhí)行clean、compile和bundle三個(gè)腳本命令。
- clean是一個(gè)清理型的腳本命令,它會(huì)使用rimraf模塊(類(lèi)似于rm -rf)來(lái)刪除dist目錄。
- compile是一個(gè)編譯型的腳本命令,它會(huì)使用tsc模塊(TypeScript編譯器)來(lái)編譯src目錄下的所有.ts文件,并輸出到dist目錄下。
- bundle是一個(gè)打包型的腳本命令,它會(huì)使用webpack模塊(打包工具)來(lái)打包dist目錄下的所有.js文件,并輸出到dist目錄下。
實(shí)例二:使用scripts字段來(lái)運(yùn)行和調(diào)試項(xiàng)目
假設(shè)我們有一個(gè)使用Express和Nodemon開(kāi)發(fā)的項(xiàng)目,我們可以在scripts字段中定義以下幾個(gè)腳本命令:
{
"scripts": {
"start": "node index.js",
"dev": "nodemon index.js",
"debug": "node --inspect index.js"
}
}這樣,我們就可以通過(guò)npm start、npm run dev或npm run debug來(lái)運(yùn)行和調(diào)試我們的項(xiàng)目。其中:
- start是一個(gè)啟動(dòng)型的腳本命令,它會(huì)使用node模塊來(lái)運(yùn)行index.js文件,這是我們項(xiàng)目的入口文件。
- dev是一個(gè)開(kāi)發(fā)型的腳本命令,它會(huì)使用nodemon模塊來(lái)運(yùn)行index.js文件,并且在文件發(fā)生變化時(shí)自動(dòng)重啟,這樣可以方便我們實(shí)時(shí)看到修改的效果。
- debug是一個(gè)調(diào)試型的腳本命令,它會(huì)使用node模塊的–inspect參數(shù)來(lái)運(yùn)行index.js文件,并且開(kāi)啟調(diào)試模式,這樣可以讓我們使用Chrome DevTools或其他調(diào)試工具來(lái)斷點(diǎn)、單步執(zhí)行、查看變量等等。
實(shí)例三:使用scripts字段來(lái)測(cè)試和發(fā)布項(xiàng)目
假設(shè)我們有一個(gè)使用Jest和npm-publish-git-tag開(kāi)發(fā)的項(xiàng)目,我們可以在scripts字段中定義以下幾個(gè)腳本命令:
{
"scripts": {
"test": "jest",
"prepublishOnly": "npm test",
"publish": "npm-publish-git-tag"
}
}這樣,我們就可以通過(guò)npm test、npm publish或npm run publish來(lái)測(cè)試和發(fā)布我們的項(xiàng)目。其中:
test是一個(gè)測(cè)試型的腳本命令,它會(huì)使用jest模塊(測(cè)試框架)來(lái)運(yùn)行test目錄下的所有測(cè)試用例,并輸出測(cè)試結(jié)果和覆蓋率報(bào)告。prepublishOnly是一個(gè)發(fā)布前型的腳本命令,它會(huì)在npm publish之前執(zhí)行,用來(lái)確保我們?cè)诎l(fā)布前通過(guò)了所有的測(cè)試。publish是一個(gè)發(fā)布型的腳本命令,它會(huì)使用npm-publish-git-tag模塊(發(fā)布工具)來(lái)發(fā)布我們的項(xiàng)目,并且自動(dòng)創(chuàng)建一個(gè)與package.json中的version字段相同的git標(biāo)簽,并推送到遠(yuǎn)程倉(cāng)庫(kù)。 結(jié)語(yǔ)
以上就是我對(duì)package.json和scripts字段的介紹,希望對(duì)大家有所幫助。scripts字段是一個(gè)非常強(qiáng)大和靈活的功能,可以讓我們?cè)趐ackage.json文件中定義和管理各種各樣的腳本命令,從而提高我們開(kāi)發(fā)和維護(hù)項(xiàng)目的效率和質(zhì)量。當(dāng)然,scripts字段還有很多其他的用法和技巧,我就不一一列舉了,有興趣的朋友可以自己去探索和嘗試。
到此這篇關(guān)于實(shí)例解析package.json和最常見(jiàn)的scripts字段的文章就介紹到這了,更多相關(guān)package.json和scripts字段內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
BootStrap自定義popover,點(diǎn)擊區(qū)域隱藏功能的實(shí)現(xiàn)
下面小編就為大家分享一篇BootStrap自定義popover,點(diǎn)擊區(qū)域隱藏功能的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
javascript實(shí)現(xiàn)搜索篩選功能實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于javascript實(shí)現(xiàn)搜索篩選功能的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Javascript腳本獲取form和input內(nèi)容的方法(兩種方法)
隨著js的發(fā)展,許多的網(wǎng)頁(yè)數(shù)據(jù)處理完全可以由js腳本解決,而不需要發(fā)送到服務(wù)器,這里分享兩種Javascript腳本獲取form和input內(nèi)容的方法,感興趣的朋友跟隨小編一起看看吧2023-05-05
js前端實(shí)現(xiàn)登錄拼圖驗(yàn)證功能
行為驗(yàn)證碼通過(guò)用戶的操作來(lái)完成驗(yàn)證,常見(jiàn)的行為驗(yàn)證碼有拖動(dòng)式和點(diǎn)觸式,下面這篇文章主要給大家介紹了關(guān)于js前端實(shí)現(xiàn)登錄拼圖驗(yàn)證功能的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
js return返回多個(gè)值,通過(guò)對(duì)象的屬性訪問(wèn)方法
下面小編就為大家?guī)?lái)一篇js return返回多個(gè)值,通過(guò)對(duì)象的屬性訪問(wèn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02

