简介
核心特性:
* 通过事件循环机制快速分发处理事件
* 除了你的代码,一切都是并行的
- 但是nodejs是单线程的,可是采用非阻塞方式处理大部分IO任务(异步IO模式)
* nodejs线程会持续进行事件循环,直到所有任务都完成后退出。当有事件发生时,nodejs会触发相应的回调函数
* nodejs开发本质是编写事件回调函数。多个事件会触发多个回调函数,但是同一时刻只有一个回调函数被执行。
NodeJS运行的两个阶段
第一阶段是初始化, 代码会导入依赖库、读配置参数等,这时可以考虑同步操作
第二阶段是事件循环阶段,这时多是IO操作,不要使用同步文件操作避免阻塞其他事件
开发模式:
* 回调函数、错误处理、在事件驱动编程中广泛使用的Emitter和Stream
安装:
* 可以docker运行
语法
入门:
- use strict; // 严格检查代码语法
- const fs = require('fs'); // const 声明为常量(如果声明为变量使用let),require引入其他模块
- fs.watch('target.txt',()=>console.log('File changed!')); // watch 接收两个参数,
// 第一个是待观察的文件,第二个是回调函数。
// ()=> 表示回调函数不需要入参, console.log('File changed!') 表示回调函数行为
// 这个可以写成: function(){ console.log('File changed!') ; } - console.log('start watch target.txt...'); // 提示开始进入事件循环阶段
事件循环会一直持续,直到没有任何代码需要执行,没有任何事件需要等待,或者程序由于其他因素退出
改成EventEmitter
EventEmitter是Nodejs中非常重要的一个类,可以通过它触发事件或是响应事件。
用法例子:
ls.stdout.on('data',chunk => output += chunk );
on用于给指定事件添加事件监听函数,本例监听的是data事件,事件发生后拿到数据。
读文件
- readFile(异步)
use strict;
const fs = require('fs'); // const 声明为常量(如果声明为变量使用let),require引入其他模块
fs.readFile('target.txt',(err,data)=>{
if( err ){
throw err;
}
console.log(data.toString());
});
- CreateReadStream + EventEmitter
require('fs').CreateReadStream(filename)
.on('data', chunk=>process.stdout.write(chunk))
.on('error', err=>process.stderr.write(`ERROR: ${err.message}\n`)) );
- readFileSync
类继承
const EventEmitter = require('events').EventEmitter;
class LDJClient extends EventEmitter{
constructor(stream){
supper();
}
};
Async/Await基本规则
async 表示这是一个async函数,await只能用在这个函数里面。
await 表示在这里等待promise返回结果了,再继续执行。
await 后面跟着的应该是一个promise对象(当然,其他返回值也没关系,只是会立即执行,不过那样就没有意义了…)
包管理
npm
Node默认的模块管理器
package.json
一般只存在于项目的根路径下,定义了这个项目所需要的各种模块,以及项目的配置信息(比如名称、版本、依赖项等信息)。可以通过 npm init [-y] 命令使用向导的形式创建该文件。
网友评论