1. 理论部分
1.1 Node.js简介
- Node.js是运行在服务端的JavaScript
- Node.js是基于Chrome JavaScript运行时建立的一个平台
- Node.js是事件驱动I/O服务端JavaScript环境,基于Google的V8引擎
注:V8引擎执行Javascript的速度非常快,性能非常好
1.2 npm的概念
NPM是JavaScript开发人员可以轻松共享和重用代码,并且可以更轻松更新你所共享的代码。
1.3 npm包的分类
1.3.1 全局安装与全局npm包
- 通过“npm install -g <package_name>”命令生成
- 在任一目录下通过require函数传递npm包的绝对路径引用
- 无法通过npm包名称直接引用
1.3.2 本地安装与本地npm包
- 项目文件夹内通过“npm install <package_name>”命令生成
- 项目文件夹内可直接通过require函数传递本地npm包名称引用
- 本地安装的项目文件夹支持自定义(如,/var/www/project1)
2 使用方法
2.1 配置Node.js环境
2.1.1 配置Node.js的源
1
<code>yum </code><code>install</code> <code>-y http:</code><code>//rpm</code><code>.nodesource.com</code><code>/pub_8</code><code>.x</code><code>/el/7/x86_64/nodesource-release-el7-1</code><code>.noarch.rpm</code>
2.1.2 安装Node.js
<code>yum </code><code>install</code> <code>-y nodejs-8.1.3</code>
2.1.3 校验安装
2.1.3.1 校验Node.js
<code>node -</code><code>v</code>
显示如下:
<code>v8.1.3</code>
2.1.3.2 校验npm
<code>npm -</code><code>v</code>
<code>5.0.3</code>
2.1.4 创建npm管理用户
2
<code>useradd</code> <code>npm</code>
<code>su</code> <code>- npm</code>
注:如无特殊说明第2章节往下代码都使用npm用户身份执行,而非root
2.1.5 配置全局npm目录
2.1.3.1 查找npm默认路径
<code>npm config get prefix</code>
<code>/usr</code>
2.1.3.2 新建npm全局目录
<code>mkdir</code> <code>~/.npm-global</code>
2.1.3.3 新建npm全局目录
<code>npm config </code><code>set</code> <code>prefix </code><code>'~/.npm-global'</code>
2.1.3.4 配置npm环境变量
<code>echo</code> <code>'export PATH=~/.npm-global/bin:$PATH'</code> <code>>> ~/.bash_profile</code>
<code>source</code> <code>~/.bash_profile</code>
2.1.3.5 测试配置
<code>npm </code><code>install</code> <code>-g jshint</code>
2.2 Node.js软件包的配置
2.2.1 查看已安装的包
2.2.1.1 本地包操作1
<code>npm </code><code>ls</code>
2.2.1.2 本地包操作2
<code>npm </code><code>ls</code> <code>--depth 0</code>
2.2.1.3 全局包操作1
<code>npm </code><code>ls</code> <code>-g</code>
2.2.1.2 全局包操作2
<code>npm </code><code>ls</code> <code>-g --depth 0</code>
2.2.2 安装软件包
2.2.2.1 本地包操作
<code>npm </code><code>install</code> <code><package_name></code>
2.2.2.2 全局包操作
<code>npm </code><code>install</code> <code>-g <package_name></code>
2.2.3 安装并保存依赖关系
2.2.3.1 本地包操作
<code>npm </code><code>install</code> <code><package_name> --save</code>
注:存在“package-lock.json”文件中
2.2.3.2 全局包操作
<code>npm </code><code>install</code> <code>-g <package_name> --save</code>
2.2.5 安装并保存开发依赖关系
2.2.5.1 本地包操作
<code>npm </code><code>install</code> <code><package_name> --save-dev</code>
2.2.5.2 本地包操作
<code>npm </code><code>install</code> <code>-g <package_name> --save-dev</code>
2.2.6 查看废弃的包
2.2.6.1 本地包操作
<code>npm outdated</code>
2.2.6.2 全局包操作
<code>npm outdated -g --depth=0</code>
2.2.7 更新的软件包
2.2.7.1 本地包操作
<code>npm update <package_name></code>
2.2.7.2 全局包操作
<code>npm update -g <package_name></code>
2.2.8 卸载软件包
2.2.8.1 本地包操作
<code>npm uninstall <package_name></code>
2.2.8.2 全局包操作
<code>npm uninstall -g <package_name></code>
2.2.9 卸载软件包并保存依赖关系
<code>npm update --save <package_name></code>
<code>npm update -g --save <package_name></code>
2.3 使用package.json
2.3.1 package.json的作用
- 声明项目所需的依赖包
- 通过语义版本控制规则声明项目所需包的版本
- 是项目更冗余重复构建和共享
2.3.2 package.json的书写要求
- name
-- 全部小写
-- 单词间不允许使用空格
-- 可使用破折号与下划线
- version
-- 格式“x.x.x”
-- 遵守semver规范
范例如下:
3
4
<code>{</code>
<code> </code><code>“name”:“my-awesome-package”,</code>
<code> </code><code>“version”:“1.0.0”</code>
<code>}</code>
2.3.3 创建默认的package.json文件
<code>npm init -y</code>
验证创建
<code>cat</code> <code>/home/npm/package</code><code>.json</code>
显示如下:
5
6
7
8
9
10
11
12
<code> </code><code>"name"</code><code>: </code><code>"npm"</code><code>,</code>
<code> </code><code>"version"</code><code>: </code><code>"1.0.0"</code><code>,</code>
<code> </code><code>"description"</code><code>: </code><code>""</code><code>,</code>
<code> </code><code>"main"</code><code>: </code><code>"index.js"</code><code>,</code>
<code> </code><code>"scripts"</code><code>: {</code>
<code> </code><code>"test"</code><code>: </code><code>"echo \"Error: no test specified\" && exit 1"</code>
<code> </code><code>},</code>
<code> </code><code>"keywords"</code><code>: [],</code>
<code> </code><code>"author"</code><code>: </code><code>""</code><code>,</code>
<code> </code><code>"license"</code><code>: </code><code>"ISC"</code>
=====================================
npm参考:
----------
<a href="https://www.npmjs.com/package/cnpm" target="_blank">https://www.npmjs.com/package/cnpm</a>
<a href="https://npm.taobao.org/" target="_blank">https://npm.taobao.org/</a>
<a href="https://cnpmjs.org/" target="_blank">https://cnpmjs.org/</a>
nodejs参考:
------------
<a href="http://www.runoob.com/nodejs/nodejs-mysql.html" target="_blank">http://www.runoob.com/nodejs/nodejs-mysql.html</a>
本文转自 tanzhenchao 51CTO博客,原文链接:http://blog.51cto.com/cmdschool/1950640,如需转载请自行联系原作者