package.json相关知识记录

一、相关字段

npm官方字段介绍

🍧 bin   =>   简单理解:指定命令的名称及路径

🍉 相当于想path中添加路径,局部安装是在./node_modules/.bin/,全局安装是在全局的bin目录

🍉 bin指定的文件必须以#!/usr/bin/env node开头,系统才会使用node去执行该指定文件

🍉 npm link对开发的npm包进行调试测试的时候也可以用到

json 复制代码
// 情况1,bin字段是一个对象
// 命令行运行  =>  show xxx参数
"bin": {
	"show": "./lib/index.js"
}

// 情况2,bin字段是一个字符串
// 命令行运行  =>  [npm包名] xxx参数
"bin": "./lib/index.js"

🍧 files   =>   简单理解:发布到npm包时需要打包的文件

🍉 以下的配置在npm打包的过程中,无论设置怎样的配置文件都会被打包到npm包中

🍉 🍉 package.json

🍉 🍉 README

🍉 🍉 CHANGES / CHANGELOG / HISTORY

🍉 🍉 LICENSE / LICENCE

🍉 🍉 NOTICE

🍉 🍉 The file in the "main" field

🍉 以下的配置在npm打包的过程中,不会被打包到npm包中

🍉 🍉 .git, CVS, .svn, .hg, .lock-wscript, .wafpickle-N, .DS_Store, npm-debug.log, .npmrc, node_modules, config.gypi, package-lock.json,

🍧 types  =>   简单理解:发布到npm包时需要打包的ts类型文件

二、依赖的版本号

常见版本号修饰符 ^和~

无修饰符   =>   0.1.2 匹配版本 0.1.2
~ 修饰符   =>   ~0.1.2 匹配版本 0.1.*
^ 修饰符   =>   ^0.1.2 匹配版本 0.*.*

版本号相关参考链接

🍉 版本号比较轮子   =>   compare-versions

🍉 package.json中版本号详解

🍉 npm依赖包指定git仓库

git 校验可能用到的配置

json 复制代码
 "lint-staged": {
    "**/*.{js,jsx,ts,tsx,vue}": "leolint exec eslint"
  }

代码校验及风格化可能用到的配置

json 复制代码
"husky": {
    "hooks": {
      "commit-msg": "leolint commit-msg-scan ",
      "pre-commit": "leolint commit-file-scan"
    }
  },
  "config": {
    "commitizen": {
      "path": "./node_modules/cz-conventional-changelog"
    }
  }
相关推荐
前端一小卒12 分钟前
一个看似“送分”的需求为何翻车?——前端状态机实战指南
前端·javascript·面试
syt_101315 分钟前
Object.defineProperty和Proxy实现拦截的区别
开发语言·前端·javascript
遝靑18 分钟前
Flutter 跨端开发进阶:可复用自定义组件封装与多端适配实战(移动端 + Web + 桌面端)
前端·flutter
cypking24 分钟前
Web前端移动端开发常见问题及解决方案(完整版)
前端
长安牧笛27 分钟前
儿童屏幕时间管控学习引导系统,核心功能,绑定设备,设时长与时段,识别娱乐,APP超时锁屏,推荐益智内容,生成使用报告,学习达标解锁娱乐
javascript
老前端的功夫29 分钟前
Vue 3 vs Vue 2 深度解析:从架构革新到开发体验全面升级
前端·vue.js·架构
栀秋66639 分钟前
深入浅出链表操作:从Dummy节点到快慢指针的实战精要
前端·javascript·算法
狗哥哥1 小时前
Vue 3 动态菜单渲染优化实战:从白屏到“零延迟”体验
前端·vue.js
青青很轻_1 小时前
Vue自定义拖拽指令架构解析:从零到一实现元素自由拖拽
前端·javascript·vue.js
xhxxx1 小时前
从被追问到被点赞:我靠“哨兵+快慢指针”展示了面试官真正想看的代码思维
javascript·算法·面试