如果你是一个JavaScript系的开发者,一定不会陌生NPM,它既是一个平台,也是一个工具。在这个平台上,我们能够使用其他开发者提供的功能代码,当然我们也能将我们自己代码提交到这里分享给世界上的开发者。
以下记录一些NPM作为工具的一些使用技巧。
npmrc.npmrc 做为npm的配置文件,它可以定义在多个地方。
用户根目录,根目录内所有的npm指令都会查询到该配置
npm内建配置文件
当前项目根目录,用于配置特定于当前项目的配置
npmrc对我们来说十分有用,我们可以配置例如username、registry、email等信息。 eg:
save=true save-exact=true email=wfsovereign@outlook.com username=wfsovereign registry=https://registry.npm.taobao.orgnpm最让人头疼的问题之一就是版本号了,这里配置了save和save-exact属性,作用是让我们 npm install 指令安装的依赖自动保存在package.json文件的dependencies中并且让版本号固定。
一些国内的服务器在拉取某些被墙的包的经常会失败或者速度很慢,这个时候我们可以试试淘宝NPM镜像(这是一个完整 npmjs.org 镜像,你可以用此代替官方版本(只读),同步频率目前为 10分钟 一次以保证尽量与官方服务同步)。官方还定制了cnpm,这个看具体情况而定了。比如,我曾经的一个项目,部署在微软的Asure上面,这个服务器感觉被墙的厉害,用官方的npm库下phantomjs的zip文件运气好的话也得下个两三次才能下下来,后来为了解决这个问题尝试了淘宝镜像,不过问题就出在用了cnpm,用cnpm拉的包在本地编译不了,后来换回npm,使用淘宝镜像,一切正常了~
package.jsonpackage.json是项目的配置管理文件,它定义了这个项目所需要的各个依赖模块以及项目的配置信息(名字,版本号,许可证等)。一个最基本的package.json必须有name和version,差不多长这样:
{ "name": "xxx", "version": 0.0.0 }我们可以通过npm init指令初始化创建一个package.json文件,
{ "name": "test", "version": "1.0.0", "description": "", "main": "index.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1" }, "author": "wfsovereign", "license": "ISC", "devDependencies": { }, "dependencies": { } }下面分属性介绍
scriptsscripts定义了一些脚本指令的npm命令缩写,通过这些命令我们可以方便的启动项目、进行测试或者拿到一些钩子来做某些指令前预先做的事,
"scripts": { "pretest": "echo \"this is pre test\" ", "test": "echo \"Error: no test specified\"", "posttest": "echo \"this is post test\"" }当我们执行npm test会得到如下输出:
this is pre test
test@1.0.0 test echo "Error: no test specified"
Error: no test specified
test@1.0.0 posttest echo "this is post test"
this is post test
通过如上实验,我们能够知道,prexx指令是一个预执行指令,postxx是一个后置指令,他俩都和xx指令强相关。
mainmain指定项目加载的入口文件,默认是根目录的inde.js
filefile是一个字符串的数组,指定我们发布的包应该包含当前目录的哪些文件,这个在我们发布包的时候很有用,因为开发包里面的文件夹不是都需要发布出去的。当然一下文件是始终会被包含进去的,不论我们是否设置,
keywordskeywords指定了在库中搜索时能够被哪些关键字搜索到,所以一般这个会多写一些项目相关的词在这里,这是一个字符串的数组。
其余属性详情可以查询官方文档
semantic version关于语义化的版本号,这里不多讲,放一些preference
Nodejs项目中最常见的一些版本标识( *, ~, ^ ),经常忘了它们的含义,这里记录一下:
lodash: 4.7.0 会安装准确的4.7.0到我们的node_module目录
如何发布一个包?
说到发布包,这里在记录一些开发包的小技巧。
我们在开发包的时候免不了一些调试,但是这些调试的过程我们并不想它发布又想确保当前的功能是可用的,这个时候有两个办法能够帮助我们来解决这个问题。
关于npm link的详细介绍我们可以看官网,这里介绍三种用法:
"dependencies": { "bar": "file:../foo/bar" }ps: 继续努力啊,如风少年~