node.js学习笔记(一)package.json

package.json文件的创建

在一个node项目中,package文件可以直接创建package.json后编写里面的内容,也可以通过使用npm init来初始化(没有时即为创建)。

直接创建很容易,直接创建名为package.json文件后编写里面的内容就可以了

使用npm init创建时,会以一个问答的形式创建,通过“回答问题”来给对应的键名赋键值。

这里输入的问答会将内容写入最后的package.json文件,如果不填入内容的话会使用默认的内容或者为空,package会使用当前文件夹的名字,但名字不能为中文,如果输入错误会重新“提问”一次。

一开始使用时,其实只需要写入package name,后面的内容可以一直按回车跳过(如果当前文件夹的名字符合项目名字要求的话,也可以直接按回车跳过)。最后的json文件内容如下

1
2
3
4
5
6
7
8
9
10
11
{
"name": "demo",
"version": "1.0.0",
"description": "the first demo",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC"
}

package.json初始属性含义

以上面的代码来展示属性含义

1
2
3
4
5
6
7
8
9
10
11
{
"name": "demo", // 项目名称,只能由小写字母,数字和下划线组成
"version": "1.0.0", // 版本号
"description": "the first demo", // 对项目的描述
"main": "index.js", // 入口文件
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1" // 指定项目生命周期各个环节要做的内容
},
"author": "", // 项目作者信息
"license": "ISC" // 项目许可协议
}

使用package.json导入模块

在成功创建了package.json文件后,可以通过npm install来把依赖的模块导入

首先我们可以通过npm install mode -s 来导入需要的模块(这里的mode指代模块名,可以在https://www.npmjs.com/上查找对应的模块名),同时将该模块的名字和版本号写入pacakge.json文件中(如果此时没有创建package.json文件的话,这里会自动创建),这里以导入connect为例

导入的模块会在node_modules文件夹里面,导入模块后增加了node_modules文件夹和package-lock.json文件(如果原来没有的话),package.json文件修改为下面代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
{
"name": "demo",
"version": "1.0.0",
"description": "the first demo",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"connect": "^3.6.6"
}
}

当我们要在另一个项目中导入当前项目所使用的模块时,我们可以将package.json文件中的dependencies属性复制到新的项目中的这个属性里面(如果没有这个属性就新建这个属性),然后通过npm install就可以将之前的项目中依赖的模块导入到当前项目中。

使用npm install导入package.json文件中注明的模块,可能会更新部分内容,但不会重新导入重复内容。

dependencies属性版本号标志

nodejs所依赖的这些模块更新迭代的速度很快,要使用一个模块,需要确定自己所要使用的版本号,但有时候又不一定能使用明确的版本号,就需要使用一些版本号的标志,以connect为例

1. 不带版本号标志

当我们不带任何特殊的符号,写入一个明确的版本号时,就一定会使用该版本号,如果输入错误的版本号,在使用npm install时会报错

1
2
3
"dependencies": {
"connect": "1.0.0"//明确限制版本为1.0.0
}

2. ^

使用和当前写入的版本号兼容的版本,如果没有的话就寻找与之最近的版本

1
2
3
"dependencies": {
"connect": "^1.0.0"//使用和1.0.0兼容的版本,如果没有则使用和1.0.0最接近的版本
}

3. ~

使用近似于写入的版本号的版本,如果没有就寻找与之最近的版本,在实际使用上与^相同

1
2
3
"dependencies": {
"connect": "~1.0.0"//使用和1.0.0近似的版本,如果没有则使用和1.0.0最接近的版本
}

4. latest

使用最新的版本

1
2
3
"dependencies": {
"connect": "latest"
}

5.*
使用任意版本,但会从最新的版本开始寻找,实际使用和latest一样

1
2
3
"dependencies": {
"connect": "*"
}