返回顶部
首页 > 资讯 > 前端开发 > JavaScript >package.json是怎样的
  • 674
分享到

package.json是怎样的

2024-04-02 19:04:59 674人浏览 薄情痞子
摘要

今天就跟大家聊聊有关package.JSON是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。常用配置项filesfiles定义了哪些文件应该被

今天就跟大家聊聊有关package.JSON是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

package.json是怎样的

常用配置项

files

files定义了哪些文件应该被包括在 npm install 后的 node_modules中。

当然,有些文件是自动暴露出来的,不管你是不是配置了files,比如:

  • package.json

  • README / CHANGELOG / LICENSE

  • ...

很多库都定义了 files,避免一些不必要的文件暴露到 node_modules 中。

vite 中是这样配置的:

{   "files": [ "bin", "dist", "client.d.ts" ] }

我之前就不知道这个配置,导致我发布的一个 npm 组件 Vue-awesome-progress[3]  就暴露了源码部分,虽然这也没啥影响,本来就是开源的。但是这也增加了别人的资源下载量,也是一种浪费。所以,专业点的搞法还是加上files配置吧。

bin

bin 列出了可执行文件,表示你这个包要对外提供哪些脚本。

在这个包被 install 安装时,如果是全局安装 -g,bin 列出的可执行文件会被添加到 PATH 变量(全局可执行);如果是局部安装,则会进入到  node_modules/.bin/ 目录下。

bin 在一些 CLI 工具中用得很频繁,比如 Vue CLI。

开发 npm 包时,要求发布的可执行脚本要以#!/usr/bin/env node开头,这是为什么呢?

我查了一下,原来是为了用于指明该脚本文件要使用 node 来执行。

main, browser, module

这三个配置对我们的影响还是挺大的。

main字段决定了别人require('xxx')时,引用的是哪个模块对象。在不设置main字段时,默认值是index.js。

如果你开发的包是用于浏览器端的,那么用browser指定入口文件是最佳的选择。

module则代表你开发的包支持ESM,并指定了一个ESM入口。

具体这三个字段怎么用,还是挺有学问的,这里推荐一篇文章package.json中你还不清楚的browser,module,main  字段优先级[4],讲得挺细。

长图警告!

package.json是怎样的

scripts

scripts也基本上每天都用了,但是它的钩子脚本你用过吗?如果没有用过,可以试试,在组织脚本流程时非常好用!

  • pre:在一个script执行前执行,比如prebuild,可以在打包前做一些准备工作。

  • post:在一个script执行后执行,比如postbuild,可以在打包后做一些收尾工作。

config

通过config配置的参数xxx,可以在脚本中通过npm_package_config_xxx 的形式引用,比如port。

{   "config": {     "port": "8080"   } }

依赖相关

dependencies

dependencies可以理解为生产依赖,通过npm install --save安装的依赖包都会进入到dependencies中。

devDependencies

devDependencies可以理解为开发环境依赖,通常是一些工具类的包,比如 webpack, babel等。通过npm install  --save-dev安装的依赖包都会进入到devDependencies中。

但是,在结合一些构建工具使用时,我们往往会有困惑。比如我安装了一个包到devDependencies中,但是不小心在项目中引用了它,最后也被  WEBpack 打包到构建结果中了。这是怎么回事呢?

建议结合上篇文章npm install这一节[5]一起看。

peerDependencies

我是package-a,你装我,你就必须装我的peerDependencies。

让“调包侠”将package-a的依赖提升到自己的node_modules中,这样可以在“调包侠”和package-a都需要同一个依赖(比如vue)时,避免重复安装。这常见于开发组件或者库。

注意,一个 npm 包的开发者如果声明了peerDependencies,开发环境下在该包目录npm  install也不会在node_modules中安装这些依赖,所以往往还需要借助devDependencies。

举个例子,我开发一个组件,不想发布到 npm 时包含了 vue 的代码,这就需要外部提供 vue ,所以我把 vue 定义在  peerDependencies 也无可厚非。但是,在开发组件时,一般还需要本地开发环境跑一个 demo 试试效果,这时候是依赖 vue 的,所以还需要在  devDependencies 中安装 vue 。我看了下 vue-router 就是这么做的,所以我在开发自己的组件时也学会了这招。

bundledDependencies

bundledDependencies跟上面的依赖都不太一样,配置上不是键值对的形式,而是一个数组

{   "bundledDependencies": [     "vue",     "vue-router"   ] }

在运行npm pack时,会将对应依赖打包到tgz文件中。用得不多,不知道具体的细节,主要还是直接用npm install安装 tgz  包的场景比较少,有个概念就行。

optionalDependencies

optionalDependencies用于配置可选的依赖,即使配了这个,代码里也要做好判断(保护),否则运行报错就不好玩了。

try {   var foo = require('foo')   var fooVersion = require('foo/package.json').version } catch (er) {   foo = null }

题外话

仔细读过package.json文档后,整体上还是解决了我的不少困惑,对我开发 npm  组件也提供了不少帮助。

看完上述内容,你们对package.json是怎样的有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网JavaScript频道,感谢大家的支持。

--结束END--

本文标题: package.json是怎样的

本文链接: https://lsjlt.com/news/81693.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • package.json是怎样的
    今天就跟大家聊聊有关package.json是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。常用配置项filesfiles定义了哪些文件应该被...
    99+
    2024-04-02
  • package.json怎么配置
    这篇文章主要介绍“package.json怎么配置”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“package.json怎么配置”文章能帮助大家解决问题。 默认值...
    99+
    2024-04-02
  • package.json文件怎么创建
    这篇文章主要讲解了“package.json文件怎么创建”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“package.json文件怎么创建”吧!了解pack...
    99+
    2024-04-02
  • 最全的package.json解析
    目录1. 概述 2. name字段 3. version字段 4. description字段 5. keywords字段 6. homepage字段 7. bugs字段 8. li...
    99+
    2024-04-02
  • nodejs中的package.json的作用
    这篇文章主要讲解了“nodejs中的package.json的作用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“nodejs中的package.json的作...
    99+
    2024-04-02
  • package.json和package-lock.json怎么使用
    本文小编为大家详细介绍“package.json和package-lock.json怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“package.json和package-lock.json怎么使...
    99+
    2024-04-02
  • package.json的属性有哪些
    这篇文章主要介绍“package.json的属性有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“package.json的属性有哪些”文章能帮助大家解决问题。概述package.json必须是一...
    99+
    2023-06-29
  • Markdown.css样式是怎样的
    这篇文章给大家介绍Markdown.css样式是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Markdown.css 是一个很有意思的 CSS 样式表。它可以让 HTML 显示...
    99+
    2024-04-02
  • CSS样式表是怎样的
    这篇文章主要介绍了CSS样式表是怎样的的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇CSS样式表是怎样的文章都会有所收获,下面我们一起来看看吧。 1:内部样式表 语法:&...
    99+
    2024-04-02
  • nodejs项目中的package.json的常见配置属性是什么
    这篇文章主要讲解了“nodejs项目中的package.json的常见配置属性是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“nodejs项目中的pac...
    99+
    2024-04-02
  • package.json版本号符号^和~前缀的区别是什么
    这篇文章主要介绍“package.json版本号符号^和~前缀的区别是什么”,在日常操作中,相信很多人在package.json版本号符号^和~前缀的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”p...
    99+
    2023-07-02
  • uni-app中样式是怎么样的
    小编给大家分享一下uni-app中样式是怎么样的,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!uni-app中的样式sass插件需要在官网下载,按提示操作即可rpx 即响应式px,一种根据屏幕宽度自适应的动态单位。以750...
    99+
    2023-06-25
  • CSS3的mediaquery是怎样的
    CSS3的mediaquery是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一个媒体查询(media query)包含一个媒体类型(m...
    99+
    2024-04-02
  • package.json文件配置的示例分析
    这篇文章将为大家详细讲解有关package.json文件配置的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。package.json 是npm init命令初始化...
    99+
    2024-04-02
  • Node.js中的package.json与cnpm命令行工具怎么使用
    这篇“Node.js中的package.json与cnpm命令行工具怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“N...
    99+
    2023-07-02
  • MySQL视图是怎样的
    MySQL视图是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.视图定义及简单介绍视图是基于 SQL 语句的结果集的可视化的表,即视图...
    99+
    2024-04-02
  • Oracle结构是怎样的
    本篇内容主要讲解“Oracle结构是怎样的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle结构是怎样的”吧! 一、数据库体系结构概况 Oracle...
    99+
    2024-04-02
  • AJAX的使用是怎样
    AJAX的使用是怎样,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 首先是一个创建AJAX的函数: 代...
    99+
    2024-04-02
  • JavaScript是怎样输出的
    今天就跟大家聊聊有关JavaScript是怎样输出的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。JavaScript 是互联网上最流行的 脚本语言...
    99+
    2024-04-02
  • AJAX中XMLHttpRequest是怎样的
    本篇文章为大家展示了AJAX中XMLHttpRequest是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。 在使用XMLHttp...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作