package.json配置

package.json配置

      • 描述配置
      • 文件配置
      • 脚本配置
      • 依赖配置
      • 发布配置
      • 系统配置
      • 第三方配置

描述配置

  • name : 项目名称,第三方包可以通过npm install 包名安装

    • "name":"react"
      
  • version : 项目版本,项目版本号

    • "version" : "18.2.0"
      
  • repository : 仓库地址及版本控制信息

    • "repository": {
        "type": "git",
        "url": "https://github.com/facebook/react.git",
        "directory": "packages/react"
      }
      
  • decription : 项目描述,会展示在 npm 官网,让别人能快速了解该项目

    • "description": "React is a JavaScript library for building user interfaces."
      
  • keyword : 技术关键词,好的关键词可以帮助别人在 npm 官网上更好地检索到此项目,增加曝光率

    • "keywords": [
        "ant",
        "component",
        "components",
        "design",
        "framework",
        "frontend",
        "react",
        "react-component",
        "ui"
      ],
      
  • homepage : 项目主页的链接,通常是项目 github 链接,项目官网或文档首页

    • "homepage": "https://reactjs.org/"
      
  • bugs : 项目 bug 反馈地址,通常是 github issue 页面的链接

    • "bugs": "https://github.com/vuejs/core/issues" 
      
  • license : 项目的开源许可证

    • "license": "MIT"
      
  • author : 项目作者

    • "author": "xiaoming"
      
  • contributors : 该项目包的贡献者

    • "contributors": [
        "xxxx <xxxxx@xx.com>",
        "xxxx <xxxxx@xx.com> "
      ]
      
      "contributors": [
        {
          "name" : "xxxxx",
          "email" : "xxxxx@xx.com",
          "url" : "https://xxxxx"
        },
        {
          "name" : "xxxxx",
          "email" : "xxxxx@xx.com",
          "url" : "https://xxxxx"
        }
      ]
      

文件配置

  • files : 项目在进行 npm 发布时,可以通过 files 指定需要跟随一起发布的内容来控制 npm 包的大小,避免安装时间太长,发布时默认会包括 package.json,license,README 和main 字段里指定的文件。忽略 node_modules,lockfile 等文件,在此基础上,我们可以指定更多需要一起发布的内容。可以是单独的文件,整个文件夹,或者使用通配符匹配到的文件

    • "files": [
        "filename.js",
        "directory/",
        "glob/*.{js,json}"
      ]
      
  • type : 在 node 支持 ES 模块后,要求 ES 模块采用 .mjs 后缀文件名。只要遇到 .mjs 文件,就认为它是 ES 模块。如果不想修改文件后缀,就可以在 package.json文件中,指定 type 字段为 module

    • "type": "module"
      
  • main : 项目发布时,默认会包括 package.json,license,README 和main 字段里指定的文件,因为 main 字段里指定的是项目的入口文件,在 browser 和 Node 环境中都可以使用,如果不设置 main 字段,那么入口文件就是根目录下的 index.js

    • "main": "./index.js"
      
  • browser : main 字段里指定的入口文件在 browser 和 Node 环境中都可以使用。如果只想在 web 端使用,不允许在 server 端使用,可以通过 browser 字段指定入口

    • "browser": "./browser/index.js"
      
  • module : 项目也可以指定 ES 模块的入口文件,这就是 module 字段的作用

    • "module": "./index.mjs"
      
    • 当一个项目同时定义了 main,browser 和 module,像 webpack,rollup 等构建工具会感知这些字段,并会根据环境以及不同的模块规范来进行不同的入口文件查找

  • exports : node 在 14.13 支持在 package.json 里定义 exports 字段,拥有了条件导出的功能,exports 字段可以配置不同环境对应的模块入口文件,并且当它存在时,它的优先级最高

    • "exports": {
        "require": "./index.js",
        "import": "./index.mjs"
      
    • 这样的配置在使用 import ‘xxx’ 和 require(‘xxx’) 时会从不同的入口引入文件

    • 上面的写法等同于

    • "exports": {
        ".": {
          "require": "./index.js",
          "import": "./index.mjs"
        }
      }
      
    • exports 除了支持配置包的默认导出,还支持配置包的子路径

    • "exports": {
        "./style": "./dist/css/index.css"
      },
      
    • //原来的引入
      import `packageA/dist/css/index.css`;
      // 用户引入时
      import `packageA/style`;
      
    • 除了对导出的文件路径进行封装,exports 还限制了使用者不可以访问未在 “exports” 中定义的任何其他路径。比如发布的 dist 文件里有一些内部模块 dist/internal/module ,被用户单独引入使用的话可能会导致主模块不可用。为了限制外部的使用,我们可以不在 exports 定义这些模块的路径,这样外部引入 packageA/dist/internal/module 模块的话就会报错。

  • workspaces : 项目的工作区配置,用于在本地的根目录下管理多个子项目。可以自动地在 npm install 时将 workspaces 下面的包,软链到根目录的 node_modules 中,不用手动执行 npm link 操作

    • "workspaces": [
        "workspace-a"
      ]
      
    • 表示在 workspace-a 目录下还有一个项目,它也有自己的 package.json。

    • 通常子项目都会平铺管理在 packages 目录下,所以根目录下 workspaces 通常配置为

    • "workspaces": [
        "packages/*"
      ]
      

脚本配置

  • script : 指定项目的一些内置脚本命令,这些命令可以通过 npm run 来执行。通常包含项目开发,构建 等 CI 命令

    • "scripts": {
        "build": "webpack"
      }
      
    • 除了指定基础命令,还可以配合 pre 和 post 完成命令的前置和后续操作

    • "scripts": {
        "build": "webpack",
        "prebuild": "xxx", // build 执行之前的钩子
        "postbuild": "xxx" // build 执行之后的钩子
      }
      
    • 执行 npm run build 命令时,会按照 prebuild -> build -> postbuild 的顺序依次执行上方的命令(pnpm和yarn2已经废弃这种操作)

  • config : 设置 scripts 里的脚本在运行时的参数

    • # 设置端口号
      "config": {
        "port": "3001"
      }
      # 在执行脚本时,我们可以通过 npm_package_config_port 这个变量访问到 3001
      

依赖配置

  • dependencies : 运行依赖,也就是项目生产环境下需要用到的依赖

    • "dependencies": {
        "react": "^18.2.0",
        "react-dom": "^18.2.0"
      }
      
  • devDependencies : 开发依赖,项目开发环境需要用到而运行时不需要的依赖,用于辅助开发

    • "devDependencies": {
        "webpack": "^5.69.0"
      }
      
  • perDependencies : 同伴依赖,一种特殊的依赖,不会被自动安装,通常用于表示与另一个包的依赖与兼容性关系来警示使用者。

    • 比如我们安装 A,A 的正常使用依赖 B@2.x 版本,那么 B@2.x 就应该被列在 A 的 peerDependencies 下,表示“如果你使用我,那么你也需要安装 B,并且至少是 2.x 版本

    • "peerDependencies": {
        "react": ">=16.9.0",
        "react-dom": ">=16.9.0"
      }
      
  • optionalDependencies : 可选依赖,顾名思义,表示依赖是可选的,它不会阻塞主功能的使用,安装或者引入失败也无妨。这类依赖如果安装失败,那么 npm 的整个安装过程也是成功的

    • "optionalDependencies": {
        "colors": "^1.4.0"
      }
      
  • peerDependenciesMeta : 同伴依赖也可以使用 peerDependenciesMeta 将其指定为可选的

    • "peerDependencies": {
        "colors": "^1.4.0"
      },
      "peerDependenciesMeta": {
        "colors": {
          "optional": true
        }
      }
      
  • bundleDependencies : 打包依赖。它的值是一个数组,在发布包时,bundleDependencies 里面的依赖都会被一起打包

    • "bundleDependencies": [
        "react",
        "react-dom"
      ]
      # 在执行 npm pack 打包生成 tgz 压缩包中,将出现 node_modules 并包含 react 和 react-dom
      # 需要注意的是,这个字段数组中的值必须是在 dependencies,devDependencies 两个里面声明过的依赖才行
      
  • overrides : overrides 可以重写项目依赖的依赖,及其依赖树下某个依赖的版本号,进行包的替换

    • # 某个依赖 A,由于一些原因它依赖的包 foo@1.0.0 需要替换,我们可以使用 overrides 修改 foo 的版本号:
      "overrides": {
        "foo": "1.1.0-patch"
      }
      # 当然这样会更改整个依赖树里的 foo,我们可以只对 A 下的 foo 进行版本号重写
      "overrides": {
        "A": {
          "foo": "1.1.0-patch",
        }
      }
      

发布配置

  • private : 如果是私有项目,不希望发布到公共 npm 仓库上,可以将 private 设为 true

    • "private": true
      
  • publishConfig : npm 包发布时使用的配置

    • # 比如在安装依赖时指定了 registry 为 taobao 镜像源,但发布时希望在公网发布,就可以指定 publishConfig.registry
      "publishConfig": {
        "registry": "https://registry.npmjs.org/"
      }
      

系统配置

  • engines : 一些项目由于兼容性问题会对 node 或者包管理器有特定的版本号要求

    • "engines": {
        "node": ">=14 <16",
        "pnpm": ">7"
      }
      
  • os : 在 linux 上能正常运行的项目可能在 windows 上会出现异常,使用 os 字段可以指定项目对操作系统的兼容性要求

    • "os": ["darwin", "linux"]
      
  • cpu : 指定项目只能在特定的 CPU 体系上运行

    • "cpu": ["x64", "ia32"]
      

第三方配置

  • types/typings : 指定 TypeScript 的类型定义的入口文件

    • "types": "./index.d.ts",
      
  • unpkg : 让 npm 上所有的文件都开启 CDN 服务

    • "unpkg": "dist/vue.global.js"
      # 当我们想通过 CDN 的方式使用链接引入 vue 时。访问 unpkg.com/vue 会重定向到 unpkg.com/vue@3.2.37/3.2.27 是 Vue 的最新版本。
      
  • jsdelivr : 与 unpkg 类似

    • "jsdelivr": "dist/vue.global.js",
      # 访问 cdn.jsdelivr.net/npm/vue 实际上获取到的是 jsdelivr 字段里配置的文件地址
      
  • browserslist : 设置项目的浏览器兼容情况,babel 和 autoprefixer 等工具会使用该配置对代码进行转换。当然你也可以使用 .browserslistrc 单文件配置。

    • "browserslist": [
        "> 1%",
        "last 2 versions"
      ]
      
  • sideEffects : 显示设置某些模块具有副作用,用于 webpack 的 tree-shaking 优化

    • 比如在项目中整体引入 Ant Design 组件库的 css 文件。

    • import 'antd/dist/antd.css'; // or 'antd/dist/antd.less'
      
    • 如果 Ant Design 的 package.json 里不设置 sideEffects,那么 webapck 构建打包时会认为这段代码只是引入了但并没有使用,可以 tree-shaking 剔除掉,最终导致产物缺少样式。
      所以 Ant Design 在 package.json 里设置了如下的 sideEffects,来告知 webpack,这些文件具有副作用,引入后不能被删除

    • "sideEffects": [
        "dist/*",
        "es/**/style/*",
        "lib/**/style/*",
        "*.less"
      ]
      
  • lint-staged : 用于对 git 的暂存区的文件进行操作的工具,比如可以在代码提交前执行 lint 校验,类型检查,图片优化等操作

    • "lint-staged": {
        "src/**/*.{js,jsx,ts,tsx}": [
          "eslint --fix",
          "git add -A"
        ]
      }
      
    • lint-staged 通常配合 husky 这样的 git-hooks 工具一起使用。git-hooks 用来定义一个钩子,这些钩子方法会在 git 工作流程中比如 pre-commit,commit-msg 时触发,可以把 lint-staged 放到这些钩子方法中

  • eslintConfig : eslint的配置可以写在单独的配置文件.eslintrc.json 中,也可以写在package.json文件的eslintConfig配置项中

    • "eslintConfig": {
        "root": true,
        "env": {
          "node": true
        },
        "extends": [
          "plugin:vue/essential",
          "eslint:recommended"
        ],
        "rules": {},
        "parserOptions": {
          "parser": "babel-eslint"
        },
      }
      
  • babel : babel用来指定Babel的编译配置

    • "babel": {
        "presets": ["@babel/preset-env"],
        "plugins": [...]
      }
      
  • gitHooks : gitHooks用来定义一个钩子,在提交(commit)之前执行ESlint检查。在执行lint命令后,会自动修复暂存区的文件。修复之后的文件并不会存储在暂存区,所以需要用git add命令将修复后的文件重新加入暂存区。在执行pre-commit命令之后,如果没有错误,就会执行git commit命令

    • "gitHooks": {
        "pre-commit": "lint-staged"
      }
      

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/890586.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

文件与fd

访问文件前&#xff0c;为什么必须要打开文件&#xff1f;/ 打开文件的实质 访问文件前&#xff0c;都必须先打开它&#xff0c; 如fopen 访问文件时&#xff0c;是进程在访问 所以文件必须加载到内存中 我们要访问文件时&#xff0c;一定要通过内存访问 文件没有被打开时&am…

多线程(三):线程等待获取线程引用线程休眠线程状态

目录 1、等待一个线程&#xff1a;join 1.1 join() 1.2 join(long millis)——"超时时间" 1.3 join(long millis&#xff0c;int nanos) 2、获取当前线程的引用&#xff1a;currentThread 3、休眠当前进程&#xff1a;sleep 3.1 实际休眠时间 3.2 sleep的特殊…

SQLI LABS | SQLI LABS 靶场初识

关注这个靶场的其它相关笔记&#xff1a;SQLI LABS —— 靶场笔记合集-CSDN博客 0x01&#xff1a;SQLI LABS 靶场简介 SQLi-Labs 靶场是一个专门用于学习和测试 SQL 注入漏洞的开源靶场&#xff0c;该靶场提供了多个具有不同漏洞类型和难度级别的 Web 应用程序的环境。这些应用…

C++ | Leetcode C++题解之第477题汉明距离总和

题目&#xff1a; 题解&#xff1a; class Solution { public:int totalHammingDistance(vector<int> &nums) {int ans 0, n nums.size();for (int i 0; i < 30; i) {int c 0;for (int val : nums) {c (val >> i) & 1;}ans c * (n - c);}return …

matlab 相关

1、xcorr 本质上是两个函数做内积运算 相关算法有两种&#xff1a; 在Matlab上既可以 1.用自带的xcorr函数计算互相关&#xff0c;2.通过在频域上乘以共轭复频谱来计算互相关&#xff1b; 网友验证程序 clc;clear;close all; % s1,s2为样例数据 s1 [-0.00430297851562500;-…

[C++ 核心编程]笔记 4.1.2 struct和class的区别

4.1.2 struct和class的区别 在C中 struct和class唯一的区别就在于 默认的访问权限不同 区别: struct 默认权限为公共class 默认权限为私有 #include<iostream> using namespace std;class C1 {int m_A;//默认私有 }; struct C2 {int m_A;//默认共有 };int main() {//s…

【3dgs】Gaussian-SLAM发展关键历程梳理

【3dgs】Gaussian-SLAM 0. 写在前面1. 3D Splatting与SLAM流程2. Splatting SLAM&#xff1a;单目/RGB-D(2024年新作&#xff09;2.1 相机跟踪精度2.2 新视图渲染性能2.3 消融实验 3. Gaussian-SLAM&#xff08;Photo-SLAM&#xff09; Photo-SLAM技术原理详解 ORBSLAM3dGS&am…

超GPT3.5性能,无限长文本,超强RAG三件套,MiniCPM3-4B模型分享

MiniCPM3-4B是由面壁智能与清华大学自然语言处理实验室合作开发的一款高性能端侧AI模型&#xff0c;它是MiniCPM系列的第三代产品&#xff0c;具有4亿参数量。 MiniCPM3-4B模型在性能上超过了Phi-3.5-mini-Instruct和GPT-3.5-Turbo-0125&#xff0c;并且与多款70亿至90亿参数的…

CentOS快速配置网络Docker快速部署

CentOS快速配置网络&&Docker快速部署 CentOS裸机Docker部署1.联通外网2.配置CentOS镜像源3.安装Docker4.启动Docker5.CentOS7安装DockerCompose Bug合集ERROR [internal] load metadata for docker.io/library/java:8-alpineError: Could not find or load main class …

动力电池SOC估算方法

1. SOC介绍 电池的荷电状态SOC反映电池的剩余容量状况&#xff0c;即在一定的放电倍率下&#xff0c;当前电池的剩余容量与总容量的比值。 为了充分发挥电池性能和提高安全性&#xff0c;需要准确估算电池SOC。动力电池在使用过程中表现的高度非线性提高了SOC估算的难度&#…

(04)python-opencv图像处理——图像阈值、平滑图像、形态转换、图像梯度

目录 前言 一、图像阈值 1.1 简单的阈值法 1.2 自适应阈值 二、平滑图像 2.1 二维卷积(图像滤波) 2.2 图像模糊 2.2.1均值模糊 2.2.2高斯模糊 2.2.3 中值滤波 2.2.4 双边滤波 三、形态转换 1、腐蚀 2、膨胀 3、开运算 4、闭运算 四、图像梯度 Sobel 和 Scharr …

【Ubuntu】“Linux版PhotoShop”绘图软件的安装和汉化

【Ubuntu】“Linux版PhotoShop”绘图软件的安装和汉化 零、前言 最近换了Linux系统&#xff0c;但是写教程做PPT的时候还是得用到绘图软件&#xff0c;上网一查&#xff0c;总结对比之后发现Krita比较好用&#xff0c;故此讲解一下如何安装和汉化Krita。 壹、安装 安装很简…

探索 Python 装饰器的新境界:wrapt 库的神秘力量

文章目录 探索 Python 装饰器的新境界&#xff1a;wrapt 库的神秘力量背景&#xff1a;为何选择 wrapt&#xff1f;wrapt 是什么&#xff1f;如何安装 wrapt&#xff1f;简单的 wrapt 库函数使用方法创建简单装饰器保持元信息处理参数传递 场景应用&#xff1a;wrapt 的实际用例…

php 生成随机数

记录&#xff1a;随机数抽奖 要求&#xff1a;每次生成3个 1 - 10 之间可重复&#xff08;或不可重复&#xff09;的随机数&#xff0c;10次为一轮&#xff0c;每轮要求数字5出现6次、数字4出现3次、…。 提炼需求&#xff1a; 1&#xff0c;可设置最小数、最大数、每次抽奖生…

CentOS7.9 下安装 Docker

第一步&#xff1a; sudo yum install -y yum-utils \ > device-mapper-persistent-data \ > lvm2 第二步&#xff1a;安装 sudo wget -O /etc/yum.repos.d/docker-ce.repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo sudo yum -y install…

C语言刷题 LeetCode 删除单链表的重复节点 双指针法

题目要求 链表结构&#xff1a;题目中提到的是未排序的链表&#xff0c;链表是由一系列节点组成的&#xff0c;每个节点包含一个值&#xff08;数据&#xff09;和一个指向下一个节点的指针。去重&#xff1a;我们需要遍历链表&#xff0c;删除所有重复的节点&#xff0c;只保…

组合式API有什么好处

什么是组合式API&#xff1f; 组合式 API (Composition API) 是一系列 API &#xff08;响应式API、生命周期钩子、依赖注入&#xff09;的集合。它不是函数式编程&#xff0c;组合式 API 是以 Vue 中数据可变的、细粒度的响应性系统为基础的&#xff0c;而函数式编程通常强调…

一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB区别,适用场景

文章目录 一、常用数据库概览1.1 关系型数据库1.2 非关系型数据库1.2.1 KV数据库1.2.2 文档型数据库1.2.3 列式存储数据库1.2.4 图数据库 1.3 SQL与NoSQL区别1.3.1 结构化与非结构化1.3.2 关联和非关联1.3.3 查询方式1.3.4 事务1.3.5 总结 二、MySQL三、PostgreSQL3.1 特点、适…

ARM base instruction -- smull

有符号乘法运算 Signed Multiply Long multiplies two 32-bit register values, and writes the result to the 64-bit destination register. 将两个32位寄存器值相乘&#xff0c;并将结果写入64位目标寄存器。 64-bit variant SMULL <Xd>, <Wn>, <Wm>…

二叉树LeetCode刷题

二叉树LeetCode刷题 1. 检查两颗树是否相同2. 另一颗树的子树3. 翻转二叉树4. 判断一颗二叉树是否是平衡二叉树5. 二叉搜索树与双向链表6. 对称二叉树7. 二叉树的构建及遍历8. 二叉树的分层遍历9. 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先10. 根据一棵树的前序遍…