nodejs小结

2017-08-20  本文已影响47人  星月西

1.箭头函数

2.exports问题

exports只是module.exports属性的一个引用而已,完全可以重写这个属性,然后这个exports引用就会失效
exports更多的是为了更加方便使用,为其添加属性,如果重写exports,只是让这个变量等于另一个引用,并不会修改到导出对象

3.热更新

客户端,热更新意味着不用换包,也包含md5校验和差异更新
服务端,服务不用重启,require引用其他模块时,会缓存模块对象,即使你更新了js文件,在代码里面再次require还是会拿到之前编译好缓存在v8内存中的旧代码

4.then的第二个参数与catch的区别

catch本质只是一个语法糖,它和then(null,function(){})是等价的
但是 then的reject函数并不不会捕获当前then中resolve函数中抛出的异常

somePromise().then(function () {
  throw new Error('oh noes');
}).catch(function (err) {
  // I caught your error! :)
});

somePromise().then(function () {
  throw new Error('oh noes');
}, function (err) {
  // I didn't catch your error! :(
});

5.Promise的同步和异步问题

Promise对象在创建时,就会执行其封装的方法,但是链式调用的then方法一定会异步执行
经典面试题:

setTimeout(function() {
  console.log(1)
}, 0);
new Promise(function executor(resolve) {
  console.log(2);
  for( var i=0 ; i<10000 ; i++ ) {
    i == 9999 && resolve();
  }
  console.log(3);
}).then(function() {
  console.log(4);
});
console.log(5);

最终的输出结果为23541
因为,Promise里面的函数是直接执行的,而Promise的then会放到当前tick的最后,但是还是在当前tick中,执行完了当前tick,再到下一个tick执行setTimeout异步代码

6.Events模块

const EventEmitter=require('events');

let event=new EventEmitter();

event.on('red',()=>{
  console.log('red');
});

event.emit('red');
console.log('green');

最终输出结果为red green
因为emit是同步地去触发事件,就会直接执行事件处理程序,在执行下一步操作

7.同步/异步

function sleep(ms){
  let start=Date.now();
  let next=start+ms;
  while(Date.now()<next);
  return;
}

8.Node的异步IO

Node的执行模型为事件循环
进程启动时,Node会创建一个类似while(true)的循环,每执行一次循环体的过程称为Tick,每个Tick的过程就是查看是否有事件待处理,有就取出事件及其相关的回调函数,然后进入下个循环

9.非IO的异步API

nodejs的特点是事件循环,其中不同的事件会分配到不同的事件观察者身上,比如idle观察者,定时器观察者,IO观察者等等,事件循环每次循环成为一次Tick,每次Tick按照先后顺序从事件观察者中取出事件进行处理

10.async异步执行函数

上一篇 下一篇

猜你喜欢

热点阅读