Package.json详解

引言

前端需要学习的东西真的挺多的,之前主要从事的是MVC框架,操作DOM,使用JQUERY比较多,不知到什么时候,发现现在前端MVVM是主流,不得不把之前的大部分东西丢掉,作为前端婴儿不断前行。

所以以后的文章,可能开始都比较基础,希望大拿不要见笑,若有不对的地方,希望指正,我也会不断修正迭代。

在学习MVVM(react和vue)的时候,开始就是会找iview,element,ant-pro等现成的东西,去改。CLI直接安装,也没有想去学习webpack。现在看更早一点的自己,真的是傻的可爱,就是那种没有方法的新手,弄出来完事。真的要专注一个领域,还是要每个方面都要研究透,要有逻辑的思考。

以下,就是在工作过程中,自己提问题,自己找答案的。有时候觉得挺有趣,看着看着,发现原来npm指令是这样来的,那不仅要弄清楚webpage,npm后续也要多学习。在程序里,任何东西都是有关联的。

生命不息,行走不止,学习不停。

1.概念

Node.js项目遵循模块化的架构,当我们创建了一个Node.js项目,意味着创建了一个模块,这个模块的描述文件,被称为package.json

亦即:模块的描述文件 = package.json

2.属性

name:包名

version:版本号

main  入口文件

license:项目许可

scripts:声明一系列npm脚本指令

dependencies:项目在生产环境中依赖的包-install的东西

devDependencies:项目在开发和测试环境中依赖的包

repository: 项目代码存放地方(git地址)

3.生成

自己生成package.json,在项目根目录下面npm init即可

另,解决了一个疑问,安装项目的时候,用的命令为什么不同?什么时候用npm run dev,什么时候用npm start ?

答案:看 scripts

"scripts": {

    "start": "set NODE_ENV=‘development‘ && webpack-dev-server --inline --progress --config ./build/webpack.config.development.js",

    "build": "set NODE_ENV=‘development‘ && webpack --config ./build/webpack.config.production.js"

  },

在package.json的script里面看配置的脚本指令,再查看对应的文件。

start里面可以看到端口;build打包编译,start,启动

有点小开心哦!嗯,明白了!

引申:package-lock.json

  1. package.json文件记录你项目中所需要的所有模块。当你执行npm install的时候,node会先从package.json文件中读取所有dependencies信息,然后根据dependencies中的信息与node_modules中的模块进行对比,没有的直接下载,已有的检查更新(最新版本的nodejs不会更新,因为有package-lock.json文件,下面再说)。另外,package.json文件只记录你通过npm install方式安装的模块信息,而这些模块所依赖的其他子模块的信息不会记录。
  2. package-lock.json文件锁定所有模块的版本号,包括主模块和所有依赖子模块。当你执行npm install的时候,node从package.json文件读取模块名称,从package-lock.json文件中获取版本号,然后进行下载或者更新。因此,正因为有了package-lock.json文件锁定版本号,所以当你执行npm install的时候,node不会自动更新package.json文件中的模块,必须用npm install packagename(自动更新小版本号)或者npm install [email protected](指定版本号)来进行安装才会更新,package-lock.json文件中的版本号也会随着更新。
  3. 附:当package.json与package-lock.json都不存在,执行"npm install"时,node会重新生成package-lock.json文件,然后把node_modules中的模块信息全部记入package-lock.json文件,但不会生成package.json文件,此时,你可以通过"npm init --yes"来初始化生成package.json文件。

总结:

  • 项目中引入的包版本号之前经常会加^号,每次在执行npm install之后,下载的包都会发生变化,为了系统的稳定性考虑,每次执行完npm install之后会创建或者更新package-lock文件。该文件记录了上一次安装的具体的版本号,相当于是提供了一个参考,在出现版本兼容性问题的时候,就可以参考这个文件来修改版本号即可。
  • 重新install删掉lock

原文地址:https://www.cnblogs.com/rong88/p/11664337.html

时间: 2024-10-23 18:40:33

Package.json详解的相关文章

npm中package.json详解

通常我们使用npm init命令来创建一个npm程序时,会自动生成一个package.json文件.package.json文件会描述这个NPM包的所有相关信息,包括作者.简介.包依赖.构建等信息,格式是严格的JSON格式. 属性介绍 name name和version是package.json中最重要的两个字段,也是发布到NPM平台上的唯一标识,如果没有正确设置这两个字段,包就不能发布和被下载. version 包的版本号.如"1.0.0". description 包的描述信息,将

(译)package.json详解

原文链接 概述 本文囊括了所有package.json文件中你需要知道的细节.注意package.json必须是纯JSON的,而不仅仅是一个JavaScript对象字面量.该文件描述的很多行为都受npm-config中的配置影响. 下面分别介绍package.json中各个字段的含义和用法. name name和version字段是package.json文件中最重要的字段.这是必须的字段,如果你的npm包没有指定这两个字段,将无法被安装.name和version字段被假定组合成一个唯一的标识符

React package.json详解

下面是一个更完整的package.json文件. { "name": "Hello World", "version": "0.0.1", "scripts": { "start": "node index.js" }, "dependencies": { "express": "latest", "

问题:JsonConvert;结果:JSON详解

JSON详解 JSON的全称是”JavaScript Object Notation”,意思是JavaScript对象表示法,它是一种基于文本,独立于语言的轻量级数据交换格式.XML也是一种数据交换格式,为什么没 有选择XML呢?因为XML虽然可以作为跨平台的数据交换格式,但是在JS(JavaScript的简写)中处理XML非常不方便,同时XML标记比数据 多,增加了交换产生的流量,而JSON没有附加的任何标记,在JS中可作为对象处理,所以我们更倾向于选择JSON来交换数据.这篇文章主要从以下几

JSON详解+ C# String.Format格式说明+ C# ListView用法详解 很完整

JSON详解 C# String.Format格式说明 C# ListView用法详解 很完整

jQuery解析json详解

jQuery解析Json详解:http://www.cnblogs.com/madyina/p/3448518.html JSON简介及用法:http://bbs.html5cn.org/thread-87020-1-1.html 不建议使用eval()函数,因为eval()接受任意的字符串,并当作JavaScript代码来处理,这个机制已经有安全隐患了 var str='{ "name": "John" }'; var obj = eval  ('(' + str

Android Gson解析json详解

目前解析json有三种工具:org.json(Java常用的解析),fastjson(阿里巴巴工程师开发的),Gson(Google官网出的),解析速度最快的是Gson,下载地址:https://code.google.com/p/google-gson/ 什么是JSON: JSON即JavaScript Object Natation, 它是一种轻量级的数据交换格式, 与XML一样, 是广泛被采用的客户端和服务端交互的解决方案. JSON对象: JSON中对象(Object)以"{"

Json详解以及fastjson使用教程

Json是一种轻量级的数据交换格式,采用一种“键:值”对的文本格式来存储和表示数据,在系统交换数据过程中常常被使用,是一种理想的数据交换语言.在使用Java做Web开发时,不可避免的会遇到Json的使用.下面我们就简单讲一下Json的使用以及fastjson.jar包的使用. 一:JSON形式与语法1.1:JSON对象我们先来看以下数据: { "ID": 1001, "name": "张三", "age": 24}第一个数据就

json详解

JSON技术 1.json介绍与入门 提示:js继承,js闭包,js原型对象 键值对,格式的数据.类似Map集合的数据结构 properties 集合键值对数据 轻量级:键值对,结构简单 重量级:xml格式,结构复杂 1.1.什么是json 中括号保存数组. 1.2.json数据的格式 键值对: 对象: 数组: 格式讲解: "employee":[ {"username1" : "zhangsan1","age1" : &qu