package.json文件描述了一个NPM包的所有相关信息,包括作者、简介、包依赖、构建等信息。格式必须是严格的JSON格式。

通常我们在创建一个NPM程序时,可以使用npm init命令,通过交互式的命令,自动生成一个package.json文件,里面包含了常用的一些字段信息,但远不止这么简单。通过完善package.json文件,我们可以让npm命令更好地为我们服务。

如果你有个新的项目,还没有下载过任何的npm包,而需要的npm包跟前一个项目差不多。那么,你可以把这个项目里面的package.jn拷贝到当前项目根目录。然后npm install,所有的依赖包就会自动的下载完毕了!

 {
//必须,标识;不能包含node,js等字段;将会是url的一部分
//命令行的参数,目录名。所以不能移点号和下划线开头
"name": "webpack-react",
//name和version组成的标识是唯一的,改变包的时候应该同时改变version
"version": "1.0.0",
//简介,方便npm search中查找
"description": "",
//程序入口模块的id,调用此包时,返回的是该模块(index)的导出(export)
"main": "server.js",
/* *repository: 代码存放地址 可选字段 */
"repository": "git://github.com/panqianjin/hello.git",
//同description 可选字段
"keywords": [ "test", "cortex" ],
//普通licesnse可直接使用 你应该要指定一个许可证,让人知道使用的权利和限制的。
// 如果你有更复杂的许可条件,或者想要提供给更多地细节,可以这样:
/* "licenses" : [
{ "type" : "MyLicense"
, "url" : "http://github.com/owner/project/path/to/license"
}
]
*/
"license": "MIT",
//当前包所依赖的其他包。即生产环境
"dependencies": {
"babel-preset-react": "^6.5.0",
"react": "^0.14.7",
"react-dom": "^0.14.7",
"webpack": "^1.12.15"
},
// 外部测试或文档框架。即测试环境依赖
// 如果只需要下载使用某些模块,而不下载这些模块的测试和文档框架,
// 放在这个下面比较不错
"devDependencies": {
"babel-core": "^6.7.2",
"babel-loader": "^6.2.4",
"babel-preset-es2015": "^6.6.0",
"babel-preset-stage-1": "^6.5.0",
"css-loader": "^0.23.1",
"file-loader": "^0.8.5",
"html-webpack-plugin": "^2.14.0",
"less-loader": "^2.2.3",
"react-hot-loader": "^1.3.0",
"style-loader": "^0.13.0",
"webpack-dev-server": "^1.14.1"
},
//engines: 既可以指定node版本也可以指定npm版本
"engines": {
"node": ">=0.10.0"
},
// *script 由脚本命令组成的hash对象在包不同生命周期运行 *
// key 时生命周期事件,value时要运行的命令
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"start_html":"webpack --config webpack.html.config.js",
"start_es6":"webpack --config webpack.es6.config.js",
"start_react":"webpack --config webpack.react.config.js",
"start_todo":"webpack --config webpack.todo.config.js",
"build":"webpack-dev-server --port 3000 --hot --inline",
"build_es6":"webpack-dev-server --port 4000 --hot --inline --config webpack.es6.config.js",
"build_todo":"webpack-dev-server --port 4000 --hot --inline --config webpack.todo.config.js"
},
/* *homepage:项目官网 可选字段*/
"homepage": "http://github.com/panqianjin/hello"
"author": {
"name": "qianjin.pan",
"email": "qinajin.pan@dianping.com"
},
//问题追踪系统的url或者邮箱 可选字段
"bugs": {
"url": "http://github.com/panqianjin/hello/issues"
},
// 指定你的包可以在哪些系统平台下运行
"os": [ "darwin", "linux", "!win32" ],
// 可以指定包运行的cpu架构
"cpu": [ "x64", "!arm" ]
} /*
"scripts": { "start": "node server.js" } 如果在项目根目录下含有server.js
文件,则NPM会自动设置此值。 "scripts": { "preinstall": "node-gyp rebuild" }
如果在项目根目录下含有binding.gyp文件,则NPM会自动设置此值 */

package.json-nodeJs的更多相关文章

  1. NodeJS中 package.json各属性分析

    package.json 中包含各种所需模块以及项目的配置信息(名称.版本.许可证等)meta 信息. Name:它属于必须字段,在package.json中最重要的就是name和version字段, ...

  2. NodeJS中 package.json 解析

    package.json 中包含各种所需模块以及项目的配置信息(名称.版本.许可证等)meta 信息. 包含可配置项 name 名称 应用描述 description 版本号 version 应用的配 ...

  3. NodeJS package.json

    #3 NodeJS package.json 工作目录 package.json 导航至工作目录后,执行下图中的命令

  4. nodejs package.json详细解读

    package.json详细内容 它是这样一个json文件(注意:json文件内是不能写注释的,复制下列内容请删除注释): JavaScript { "name": "t ...

  5. nodejs的package.json依赖dependencies中 ^ 和 ~ 的区别

    nodejs的package.json定义了一个模块,包括其依赖关系的一个简单的JSON文件,该文件可以包含多个不同的指令来告诉Node包管理器如何处理模块. dependencies则表示此模块依赖 ...

  6. [转]nodejs中package.json和package-lock.json文件的功能分析

    本文转自:https://blog.csdn.net/u013992330/article/details/81110018 最新版nodejs中,多了一个package-lock.json文件,刚开 ...

  7. 如何编写package.json配置NodeJS项目的模块声明

    在NodeJS项目中,用package.json文件来声明项目中使用的模块,这样在新的环境部署时,只要在package.json文件所在的目录执行 npm install 命令即可安装所需要的模块. ...

  8. nodejs的package.json

    package.json文件会描述这个NPM包的所有相关信息,包括作者.简介.包依赖.构建等信息,格式是严格的JSON格式 在E:/nodejs/mychat下 执行,npm init 输入yes,就 ...

  9. npm安装socket.io时报错的解决方法(npm WARN enoent ENOENT: no such file or directory, open '/usr/local/nodejs/bin/package.json')

    执行 npm install socket.io安装时报错: [root@WEB node_modules]# npm install socket.ionpm WARN enoent ENOENT: ...

  10. nodeJs 安装 npm nodeModules package.json

    Nodejs   1.安装nodejs 从nodejs官网下载最新版本的node,设置环境变量这样就可以在cmd下直接用命令行操作npm 环境变量:path  d:/nodejs 查看本机node及n ...

随机推荐

  1. Unity 代码 学习

    A B C D E F G H I J K L M N O P Q R S T U V W X Y Z A: B: using System; using System.Runtime.Compile ...

  2. RTSP为什么VLC播放器无法播放

    rtsp_tracepoint: rtspservice.c,RTSP_state_machine, state_machine:current state is ready state curren ...

  3. day5 大纲

    01 昨日内容回顾 list: 增: append insert(index,object) extend() 迭代着追加 删: pop(默认删除最后一个)按照索引去删除 有返回值 remove 按照 ...

  4. Git安装及密钥的生成(转)

    1.下载Git软件:http://msysgit.github.io/ 2.安装git软件(很简单).安装成功后,在[开始]->[程序]->[git],下就会看见Git Bash和Git ...

  5. ASP.NET AJAX入门系列(5):使用UpdatePanel控件(二) UpdatePanel

    UpdatePanel可以用来创建丰富的局部更新Web应用程序,它是ASP.NET 2.0 AJAX Extensions中很重要的一个控件,其强大之处在于不用编写任何客户端脚本,只要在一个页面上添加 ...

  6. HanLP用户自定义词典源码分析详解

    1. 官方文档及参考链接 l 关于词典问题Issue,首先参考:FAQ l 自定义词典其实是基于规则的分词,它的用法参考这个issue l 如果有些数量词.字母词需要分词,可参考:P2P和C2C这种词 ...

  7. HTTP请求回调IM系统LB,确保服务定向调用

    1. 背景介绍 基于websocket的及时通信中,客户端与服务端建立ws连接后,服务端将业务继续传递到下一级业务服务系统Business server后,下一级服务系统处理完毕后,要将结果反馈给客户 ...

  8. ML平台_微博深度学习平台架构和实践

    ( 转载至: http://www.36dsj.com/archives/98977)  随着人工神经网络算法的成熟.GPU计算能力的提升,深度学习在众多领域都取得了重大突破.本文介绍了微博引入深度学 ...

  9. 使用Vivado的block design

    使用Vivado的block design (1)调用ZYNQ7 Processing System (2)配置ZYNQ7系统 (3)外设端口配置 根据开发板原理图MIO48和MIO49配置成了串口通 ...

  10. msp430学习笔记-DAC12

    MSP430F169 的DAC12 模块有2 个DAC 通道,并且可以用DAC12GRP控制位将多个DAC12通道组合起来,实现同步更新,硬件还能确保同步更新独立于任何中断或者NMI事件. DAC12 ...