Webcourse/11-Node.js和模块化/01-Node.js介绍和环境配置.md

565 lines
14 KiB
Markdown
Raw Normal View History

2018-03-02 14:12:14 +08:00
## Node.js的介绍
2020-04-09 15:24:26 +08:00
### 什么是 Node.js官方解释
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
Node.js 是一个基于 **Chrome V8** 引擎的 JavaScript 代码运行环境。 Node.js使用了一个**事件驱动**、**非阻塞式I/O**的模型( Node.js的特性使其轻量级又高效。 Node.js 的包管理器 npm 是全球最大的开源库生态系统。
2018-03-02 14:12:14 +08:00
![](http://img.smyhvae.com/20180301_1540.png)
如上图所示:
- Node 内部采用 Google Chrome 的 V8 引擎,作为 JavaScript 语言解释器;
- 通过自行开发的 libuv 库,调用操作系统资源。
2020-04-09 15:24:26 +08:00
### 什么是 Node.js非官方解释
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
**Node.js是 JavaScript 语言在服务器端的运行环境(平台)**。Node.js 不是一门语言,也不是 JavaScript 的框架。
2018-03-04 18:18:19 +08:00
- 与PHP、JSP、Python、Perl、Ruby的“既是语言也是平台”不同Node.js的使用JavaScript进行编程运行在 Chrome 的 V8 引擎上。
- 与PHP、JSP等相比PHP、JSP、.net都需要运行在服务器程序上Apache、Naginx、Tomcat、IIS。
Node.js跳过了Apache、Naginx、IIS等HTTP服务器它自己不用建设在任何服务器软件之上。Node.js的许多设计理念与经典架构LAMP = Linux + Apache + MySQL + PHP有着很大的不同可以提供强大的伸缩能力。Node.js没有web容器。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
### 运行环境(平台)的含义
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 首先JavaScript 语言通过 Node 在服务器上运行在这个意义上Node 有点像 JavaScript 虚拟机。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 其次Node 生态系统活跃,提供了大量的开源库,使得 JavaScript 语言能与操作系统进行交互比如读写文件、新建子进程在这个层次上Node 又是属于 JavaScript 的工具库。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
### 为什么要学习服务器端开发
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 能够和后台开发的程序员更佳紧密地结合、更顺畅地沟通。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 当网站的业务逻辑需要前置时,前端人员需要学习一些后台开发的技术,以完成相应的任务。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 拓宽知识视野和技术栈,能够站在全局的角度审视整个项目。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
### 为什么选择 Node.js 做后台开发
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 使用 JavaScript 语言 开发服务器端应用。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 一些公司要求前端工程师掌握 Node.js 开发。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- Node.js 生态系统活跃,提供了大量的开源库。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
## Node.js的发展
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
### Node 的历史
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 2008年左右随着 Ajax 的逐渐普及Web 开发逐渐走向复杂化,系统化;
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 2009年2月Ryan Dahl 想要创建一个轻量级,适应现代 Web 开发的平台;
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 2009年5月Ryan Dahl 在 GitHub 中开源了最初版本同年11月JSConf 就安排了 Node 讲座;
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 2010年底Joyent 公司资助Ryan Dahl 也加入了该公司,专门负责 Node 的开发;
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 2011年7月在微软的支持下登陆 Windows 平台。PSnode 的生产环境基本是在 Linux 下。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
据 Node.js 创始人 Ryan Dahl 回忆,他最初希望采用 Ruby但是 Ruby 的虚拟机效率不行。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
注意:是 Node 选择了 JavaScript不是 JavaScript 发展出来了一个 Node。
2018-03-02 14:12:14 +08:00
### Node.js的主要应用领域
- RESTFul API
- 实时通信:如消息推送等
- 高并发
- I/O阻塞
### 知名度较高的Node.js开源项目
![](http://img.smyhvae.com/20180301_2009.png)
2020-04-09 15:24:26 +08:00
- expressNode.js中著名的web服务器框架。
- Koa下一代的 Node.js 的 Web 框架。
- mocha功能强大的 node.js 测试框架。
2018-03-02 14:12:14 +08:00
- PM2node 本来是单进程的PM2可以实现和管理多进程。
- jade非常优秀的模板引擎不仅限于 js 语言。
- CoffeeScript用简洁的方式展示 JavaScript 优秀的部分。
- Atom文本编辑器。
- socket.io实时通信框架。
2020-04-09 15:24:26 +08:00
### Node.js的特点
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 单线程
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
## Node.js 运行环境配置:通过 Node.js 安装包(不推荐)
2018-03-02 14:12:14 +08:00
去 Node.js 的[官网](https://nodejs.org/en/)下载安装包:
![](http://img.smyhvae.com/20180301_1505.png)
2020-04-09 15:24:26 +08:00
我们也可以在<https://nodejs.org/en/download/releases/> 里下载历史版本。
2018-03-02 14:12:14 +08:00
![](http://img.smyhvae.com/20180301_1507.png)
注意我们以一定要用偶数版V4、V6等)不要用奇数版比如V5因为奇数版不稳定。
2020-04-09 15:24:26 +08:00
我们并不推荐直接采用 Node.js.msiwindows或者 Node.js.pkgMac 安装包进行安装,原因如下:
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 不方便 Node.js 版本的更新;
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 无法回滚到之前的版本;
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
- 无法在多个版本之间切换(在有些项目中,我们要使用 Node 的指定版本)。
2018-03-02 14:12:14 +08:00
因此,我们暂时先不用安装 Node.js稍后用 NVM 的方式来安装 Node.js。
2020-04-09 15:24:26 +08:00
## Node.js 运行环境配置:通过 NVM推荐
**NVM**node.js version manager用来管理 node 的版本。
**我们可以先安装 NVM然后通过 NVM 安装 Node.js**。这是官方推荐的做法。
Windows 和 Mac 下安装的Node.js 的步骤如下。
### Windows 系统安装 Node.js
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
**1、安装 NVM**
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
1我们去 <https://github.com/coreybutler/nvm-windows/releases> 下载 NVM 的安装包:
2018-03-02 14:12:14 +08:00
![](http://img.smyhvae.com/20180301_1603.png)
下载下来后,直接解压到 `D:\web`目录下:
![](http://img.smyhvae.com/20180301_1610.png)
2在上面的目录中新建一个`settings.txt`文件,里面的内容填充如下:
```bash
root: D:\web\nvm
path: D:\web\nodejs
arch: 64
proxy
```
上方内容的解释:
- root 配置为:当前 nvm.exe 所在的目录
- path 配置为node 快捷方式所在的目录
- arch 配置为当前操作系统的位数32/64
- proxy 不用配置
3配置环境变量
- `NVM_HOME` = `D:\web\nvm`(当前 nvm.exe 所在目录)
- `NVM_SYMLINK` = `D:\web\nodejs` node 快捷方式所在的目录)
- PATH += `;%NVM_HOME%;%NVM_SYMLINK%`
配置成功后,重启资源管理器。
2020-04-09 15:24:26 +08:00
**2、验证**(在 cmd 命令行中输入命令)
2018-03-02 14:12:14 +08:00
1输入`nvm`命令查看环境变量是否配置成功:
![](http://img.smyhvae.com/20180301_1645.png)
2输入 `nvm ls`,查看已安装的所有 node 版本。
3输入 `nvm -v`,查看 已安装的 nvm 版本。
4输入 `node -v`,查看正在使用的 node 版本。
- **参考链接**[安装npmnvmnode](https://segmentfault.com/a/1190000011114680)
2020-04-09 15:24:26 +08:00
如果 Node 安装失败,可以参考上面这个链接。
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
**3、安装指定版本的 Node.js**
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
```bash
nvm install 版本号
2018-03-08 16:46:09 +08:00
2020-04-09 15:24:26 +08:00
# 举例
nvm install 8.10.0
```
输入 `node -v`,查看当前使用的 node 版本。
关于 NVM 的常用命令,详见下一段。
2018-04-10 22:15:23 +08:00
2020-04-09 15:24:26 +08:00
### Mac 系统安装 Node.js
**1、安装 NVM**
1打开 终端.app输入
```bash
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.8/install.sh | bash
2018-04-10 22:15:23 +08:00
```
2020-04-09 15:24:26 +08:00
安装成功的界面:
![](http://img.smyhvae.com/20180302_2126.png)
完成后nvm就被安装在了`~/.nvm`下。
如果发现安装失败:
![](http://img.smyhvae.com/20180302_2111.png)
原因Xcode 软件进行过更新。
解决办法:打开 Xcode 软件,同意相关内容即可。
2配置环境变量
编辑器打开`~/.bash_profile`文件,如果不会就输入`open ~/.bash_profile`。
补充如果你的Mac电脑里找不到`~/.bash_profile`文件,那就找找有没有`~/.profile`文件,或者`~/.bashrc`文件,或者`~/.zshrc`文件)。
在最后一行输入:
```bash
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm
```
如果你发现文件中已经存在了上面这行代码就不用往里面加了。这一步的作用是每次新打开一个bashnvm都会被自动添加到环境变量中。
最后,输入 `source ~/.bash_profile`重启环境变量的配置。
PSNVM 现在已经不支持 Homebrew 的方式来安装了。
参考链接:<https://www.jianshu.com/p/a3f8778bc0a1>
**2、验证**(在 终端命令行中输入命令)
1输入 `nvm` 命令查看环境变量是否配置成功:
2输入 `nvm ls`,查看已安装的所有 node 版本。
3输入 `nvm -v`,查看 已安装的 nvm 版本。
4输入 `node -v`,查看正在使用的 node 版本。
**3、安装指定版本的 Node.js**
和Windows下一样也是执行如下命令
```bash
nvm install 版本号
# 举例
nvm install 8.10.0
```
网速有点慢,要稍等。
![](http://img.smyhvae.com/20180302_2148.png)
输入 `node -v`,查看当前使用的 node 版本。
安装好 `Node` 之后,`npm` 也会自动安装的,输入 `npm -v`,查看 npm 的版本。
关于 NVM 的常用命令,详见下一段。
## NVM 的常用命令
> 注意,这一段说的是 NVM 的常用命令,不是 Node的 常用命令。
查看当前使用的 nvm 版本:
```bash
2018-04-10 22:15:23 +08:00
nvm -v
nvm --version
```
2020-04-09 15:24:26 +08:00
查看本地安装的所有的 Node.js 版本:
2018-03-08 16:46:09 +08:00
2020-04-09 15:24:26 +08:00
```bash
2018-03-08 16:46:09 +08:00
nvm list|ls
```
2020-04-09 15:24:26 +08:00
**安装指定版本的 Node.js**
2018-03-08 16:46:09 +08:00
2020-04-09 15:24:26 +08:00
```bash
nvm install 版本号
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
# 举例
nvm install 8.10.0
2018-03-02 14:12:14 +08:00
```
2020-04-09 15:24:26 +08:00
卸载指定版本 Node.js
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
```bash
2018-03-02 14:12:14 +08:00
nvm uninstall 版本号
```
切换使用指定版本的node
2020-04-09 15:24:26 +08:00
```bash
nvm use 版本号
2018-03-02 14:12:14 +08:00
```
2020-04-09 15:24:26 +08:00
## Node.js 的常用命令
2018-03-02 14:12:14 +08:00
2018-03-04 18:18:19 +08:00
查看 node 的版本:
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
```bash
2018-03-02 14:12:14 +08:00
$ node -v
```
执行脚本字符串:
2020-04-09 15:24:26 +08:00
```bash
2018-03-02 14:12:14 +08:00
$ node -e 'console.log("Hello World")'
```
运行脚本文件:
2020-04-09 15:24:26 +08:00
```bash
2018-03-02 14:12:14 +08:00
$ node index.js
2018-03-12 21:01:35 +08:00
2018-03-02 14:12:14 +08:00
$ node path/index.js
2018-03-12 21:01:35 +08:00
2018-03-02 14:12:14 +08:00
$ node path/index
```
查看帮助:
2020-04-09 15:24:26 +08:00
```bash
2018-03-02 14:12:14 +08:00
$ node --help
```
**进入 REPL 环境:**
2020-04-09 15:24:26 +08:00
```bash
2018-03-02 14:12:14 +08:00
$ node
```
REPL 的全称Read、Eval、 Print、Loop。类似于浏览器的控制台。
![](http://img.smyhvae.com/20180301_1900.png)
如果要退出 REPL 环境,可以输入`.exit` 或 `process.exit() `
在 VS Code 里,我们可以在菜单栏选择“帮助->切换开发人员工具”打开console控制台。
## 包和 NPM
### 什么是包
由于 Node 是一套轻内核的平台虽然提供了一系列的内置模块但是不足以满足开发者的需求于是乎出现了包package的概念
与核心模块类似,就是将一些预先设计好的功能或者说 API 封装到一个文件夹,提供给开发者使用。
Node 本身并没有太多的功能性 API所以市面上涌现出大量的第三方人员开发出来的 Package。
### 包的加载机制
如果 Node中自带的包和第三方的包名冲突了该怎么处理呢原则是
- 先在系统核心(优先级最高)的模块中找;
- 然后到当前项目中 node_modules 目录中找。
比如说:
2020-04-09 15:24:26 +08:00
```javascript
2018-03-02 14:12:14 +08:00
requiere(`fs`)
```
那加载的肯定是系统的包。所以,我们尽量不要创建一些和现有的包重名的包。
### NPM的概念
>包的生态圈一旦繁荣起来就必须有工具去来管理这些包。NPM 应运而生。
**NPM**Node Package Manager。官方链接 <https://www.npmjs.com/>
随着时间的发展NPM 出现了两层概念:
- 一层含义是 Node 的开放式模块登记和管理系统,亦可以说是一个生态圈,一个社区。
- 另一层含义是 Node 默认的模块管理器,是一个命令行下的软件,用来安装和管理 Node 模块。
### NPM 的安装(不需要单独安装)
NPM 不需要单独安装。默认在安装 Node 的时候,会连带一起安装 NPM
![](http://img.smyhvae.com/20180302_1105.png)
NVM、Node、NPM 安装之后,目录分布如下:
![](http://img.smyhvae.com/20180302_1134.png)
![](http://img.smyhvae.com/20180302_1137.png)
![](http://img.smyhvae.com/20180302_1138.png)
输入 `npm -v`,查看 npm 的版本:
![](http://img.smyhvae.com/20180302_1139.png)
如果上方命令无效,可能是之前的 node 并没有完全安装成功。解决办法:<https://segmentfault.com/a/1190000011114680>
另外Node 附带的 NPM 可能不是最新版本,可以用下面的命令,更新到最新版本:
2020-04-09 15:24:26 +08:00
```bash
2018-03-02 14:12:14 +08:00
$ npm install npm -g
```
### 配置 NPM 的全局目录(暂略)
NPM 默认安装到当前正在使用 Node 版本所在目录下。我们建议重新配置 NPM 的全局目录。
输入`npm config ls`,查看:
![](http://img.smyhvae.com/20180302_1210.png)
### NPM的常用命令
- npm init --yes
项目的初始化。执行完成后,会生成`package.json`文件。
- npm install [package]
只在当前工程下安装 package。
- npm install -g [package]
在全局环境下安装 package。
- npm run [script]
2018-05-17 14:49:03 +08:00
## NRM的安装(Win 和 Mac 通用)
2018-03-02 14:12:14 +08:00
由于 NPM 的资源都在国外有时候会被墙导致无法下载或者很慢。此时可以用到NRM。
**NRM**Node Registry Manager。作用是**切换和管理包的镜像源**。
- 项目地址:<https://www.npmjs.com/package/nrm>
- GitHub地址 <https://github.com/Pana/nrm>
2018-03-02 14:12:14 +08:00
安装 NRM
2020-04-09 15:24:26 +08:00
```bash
2018-03-02 14:12:14 +08:00
npm install -g nrm
```
![](http://img.smyhvae.com/20180302_1208.png)
**NRM 的常用命令:**
2020-04-09 15:24:26 +08:00
```bash
# 显示全部的镜像
nrm ls
2018-03-02 14:12:14 +08:00
2020-04-09 15:24:26 +08:00
# 使用淘宝的镜像
nrm use taobao
2018-03-02 14:12:14 +08:00
```
效果入下:
![](http://img.smyhvae.com/20180302_1215.png)
2018-03-08 16:46:09 +08:00
推荐的国内加速镜像淘宝:<https://npm.taobao.org/>
2018-03-02 14:12:14 +08:00
## 安装cnpm
- 项目地址:<https://npm.taobao.org/>
安装`cnpm`替换npmnpm由于源服务器在国外下载node包速度较慢cnpm使用国内镜像
```bash
npm install -g cnpm --registry=https://registry.npm.taobao.org
```
2018-10-02 22:10:26 +08:00
![](http://img.smyhvae.com/20180302_2204.png)
如果我们需要通过 cnpm 去安装一个包时,举例如下:
2020-04-09 15:24:26 +08:00
```bash
cnpm i vue
```
解释: i 指的就是 install。
2018-03-04 18:18:19 +08:00
## Node 的使用
我们可以输入`node`命令,然后在里面写 js 的代码,也可以 通过 node 运行 js 文件。比如,编写好一个 js文件`01.js`,然后在命令行输入:
2020-04-09 15:24:26 +08:00
```bash
2018-03-04 18:18:19 +08:00
node 01.js
```
就可以执行 js 程序。
2018-03-05 19:36:59 +08:00
2018-03-02 14:12:14 +08:00
## 我的公众号
2020-04-09 15:24:26 +08:00
想学习**代码之外的技能**?不妨关注我的微信公众号:**千古壹号**id`qianguyihao`)。
2018-03-02 14:12:14 +08:00
扫一扫,你将发现另一个全新的世界,而这将是一场美丽的意外:
2020-04-09 15:24:26 +08:00
![](http://img.smyhvae.com/20200101.png)
2018-03-02 14:12:14 +08:00