package.json的配置参考
package.json
文件是Node.js项目中的一个重要配置文件,用于存储项目的元数据和各种配置信息。
以下是一些常见的 package.json
配置项:
{
"name": "my-project", // 项目名称,遵循npm的命名规范
"private":true,//如果设置为 true,npm 将拒绝发布此包。
"version": "1.0.0", // 项目版本号,遵循semver规范
"description": "A short description of your project", // 项目描述
"main": "index.js", // 项目的入口文件
"bin": {
"my-cli": "./bin/my-cli.js" // 如果你想让npm install -g全局安装后,可以通过命令行直接运行某个文件,可以在这里配置
},
"scripts": {
"start": "node index.js", // 启动项目的命令
"test": "jest", // 测试命令
"lint": "eslint .", // 代码风格检查命令
"build": "webpack --config webpack.prod.js", // 构建生产环境的命令
"dev": "webpack serve --config webpack.dev.js" // 开发服务器启动命令
},
"dependencies": {
"express": "^4.17.1", // 项目运行所依赖的模块
"axios": "^0.21.1" // 其他依赖模块
},
"devDependencies": {
"jest": "^27.0.0", // 开发依赖的测试框架
"eslint": "^7.0.0", // 开发依赖的代码风格检查工具
"webpack": "^5.0.0", // 开发依赖的打包工具
"webpack-cli": "^4.0.0", // webpack的命令行工具
"webpack-merge": "^5.0.0" // 用于合并webpack配置文件
},
"peerDependencies": {
"react": "^17.0.0" // 同等依赖,表示你的包需要和其他包一起使用,且版本需要匹配
},
"optionalDependencies": {
"fsevents": "^2.0.0" // 可选依赖,如果无法安装则不会报错
},
"engines": {
"node": ">=14.0.0", // 项目所依赖的Node.js版本范围
"npm": ">=6.0.0" // 项目所依赖的npm版本范围
},
"browserslist": [
"> 0.2%", // 目标浏览器版本范围
"not dead", // 不包括已经废弃的浏览器
"not ie <= 11" // 不包括IE 11及以下版本
],
"files": [
"dist", // 发布的npm包中包含的文件和目录
"src"
],
"author": "Your Name <your.email@example.com>", // 作者信息
"license": "ISC", // 许可证信息
"repository": {
"type": "git",
"url": "git+https://github.com/your-username/my-project.git" // 项目仓库地址
},
"bugs": {
"url": "https://github.com/your-username/my-project/issues" // 项目问题跟踪地址
},
"homepage": "https://github.com/your-username/my-project#readme", // 项目主页或文档地址
"keywords": [
"example",
"project" // 项目的关键词列表
],
"publishConfig": {
"registry": "https://your-custom-registry.com" // 自定义的npm仓库地址
},
"config": {
"port": "8080" // 自定义配置,可以通过npm_package_config_port在代码中获取
},
"directories": {
"lib": "lib", // 指示库文件的位置
"test": "test" // 指示测试文件的位置
},
"types": "./index.d.ts", // TypeScript的类型定义文件
"workspaces": [
"packages/*" // 如果你的项目是一个monorepo,这里可以配置工作区的位置
],
// 其他可能的配置项...
}
配置具体描述:
name:
- 项目的名称。
- 名称的长度应小于或等于 214 个字符。
- 不能以点(
.
)或下划线(_
)开头。 - 不能包含大写字母(因为 npm 包的 URL 是基于这个名称生成的)。
- 名称应尽可能简短且语义化。
version:
- 项目的版本号,遵循语义化版本规范(semver)。
description:
- 项目的简短描述。
main:
- 项目的入口文件,通常是 JavaScript 文件。
- 当其他文件通过
require()
引入你的项目时,会加载这个文件。
scripts:
- 项目的 npm 脚本,可以包含各种启动、测试、构建等命令。
dependencies:
- 项目运行所依赖的模块列表。
- 这些依赖会被安装到生产环境。
devDependencies:
- 项目开发过程中需要的依赖,但不会在生产环境中使用。
peerDependencies:
- 同等依赖,表示你的包需要和其他包一起使用,且版本需要匹配。
optionalDependencies:
- 可选依赖,如果无法安装则不会报错。
engines:
- 指定项目所依赖的 Node.js 和 npm 的版本范围。
browserslist:
- 指定项目的目标浏览器版本,用于工具如 Autoprefixer、Babel 等。
bin:
- 指定可执行文件的位置,以便 npm install -g 时可以全局安装。
files:
- 指定在发布 npm 包时需要包含的文件列表。
author:
- 项目的作者信息。
license:
- 项目的许可证信息,如 MIT、BSD 等。
repository:
- 项目的仓库地址,如 GitHub 仓库。
bugs:
- 项目问题提交地址,通常是 GitHub issue 页面的链接。
homepage:
- 项目的主页或文档地址。
keywords:
- 项目的关键词列表,用于 npm 搜索。
publishConfig:
- 发布时使用的配置,如自定义的 npm 仓库地址。
config:
- 用于配置脚本中使用的环境变量。
directories:
- 指定项目目录的用途,如
lib
表示库文件的位置,test
表示测试文件的位置。
- 指定项目目录的用途,如
types 或 typings:
- 对于 TypeScript 项目,指定类型定义文件的位置。
workspaces:
- 对于 monorepo(多包仓库),指定工作区的位置。
private:
- 如果设置为
true
,npm 将拒绝发布此包。
- 如果设置为
sideEffects:
- 对于 webpack 等打包工具,指定模块是否有副作用(即是否每次导入时都需要执行)。
os:
- 指定模块可以在哪些操作系统上运行。
cpu:
- 指定模块可以在哪些 CPU 架构上运行。
exports:
- 定义一个包的子路径的入口点,允许其他包使用更细粒度的导入语句。
module:
- 指定 ES6 模块入口点,用于支持 ES6 模块的打包工具。
browser:
- 指定在浏览器环境中使用的入口点。
unpkg 和 jsdelivr:
- 指定用于通过 unpkg 或 jsdelivr CDN 服务的文件路径。
resolutions:
- 用于覆盖依赖项中的特定子依赖项的版本。
bundleDependencies 或 bundledDependencies:
- 列出在发布包时应该被打包的依赖项。
man:
- 指定 man 手册文件的位置。
contributors:
- 项目的贡献者列表。
funding:
- 指定项目的资金赞助信息。
评论