美文网首页工作生活
es6常用语法(二)

es6常用语法(二)

作者: 镜轩夕照 | 来源:发表于2019-07-03 23:27 被阅读0次

    Promise 对象


    Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大。它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了Promise对象.

    • 基本用法
    const promise = new Promise(function(resolve, reject) {
      // ... some code
    
      if (/* 异步操作成功 */){
        resolve(value);
      } else {
        reject(error);
      }
    });
    promise.then(function(value) {
      // success
    }, function(error) {
      // failure
    });
    

    Promise实例生成以后,可以用then方法分别指定resolved状态和rejected状态的回调函数。

     function timeout(ms) {
       return new Promise((resolve, reject) => {
         setTimeout(resolve, ms, 'done');
       });
     }
     
     timeout(100).then((value) => {
       console.log(value);
     });
    

    Generator 函数的语法

    • 基础语法

    Generator 函数有多种理解角度。语法上,首先可以把它理解成,Generator 函数是一个状态机,封装了多个内部状态。

    function* Test() {
      yield 'start';
      yield 'next';
      return 'end';
    }
    
    var hw = Test();
    hw.next()
    // { value: 'start', done: false }
    
    hw.next()
    // { value: 'next', done: false }
    
    hw.next()
    // { value: 'end', done: true }
    
    hw.next()
    // { value: undefined, done: true }
    

    上面代码定义了一个 Generator 函数helloWorldGenerator,它内部有两个yield表达式(start和next),即该函数有三个状态:star,next 和 return 语句(结束执行)。

    yield 表达式,遇到yield表达式,就暂停执行后面的操作,并将紧跟在yield后面的那个表达式的值,作为返回的对象的value属性值

    function* gen() {
      yield  12+10;
      yield  method();
    }
    
    • Generator 函数的异步应用

    async 函数

    async 函数就是 Generator 函数的语法糖。它是平时最常用的异步函数。

    const asyncReadFile = async function () {
      const f1 = await readFile('/etc/fstab');
      const f2 = await readFile('/etc/shells');
      console.log(f1.toString());
      console.log(f2.toString());
    };
    

    由于async函数返回的是 Promise 对象,可以作为await命令的参数。所以,上面的例子也可以写成下面的形式。

    //
    function timeout(msg,ms) {
      return new Promise((resolve) => {
        setTimeout(function(){
          resolve(msg)
        }, ms);
      });
    }
    async function asyncPrint(msg, ms) {
      let a = await timeout(msg,ms);
      console.log(a);
    }
    asyncPrint('ok', 1000);//1s后打印 ok
    //await 后也可以直接返回值
    function Sync(ms) {
      return ms
    }
    async function Test(ms) {
      let a =  await Sync(ms);
      console.log(a);
    }
    Test('ok') //ok
    

    返回 Promise 对象

    async function fuc() {
      return 'ok';
    }
    
    fuc().then(r => console.log(r))
    // 'ok'
    

    错误处理

    async function func() {
      await new Promise(function (resolve, reject) {
        throw new Error('出错了');
      });
    }
    
    func()
    .then(v => console.log(v))
    .catch(e => console.log(e))
    // Error:出错了
    

    Class语法

    ES6 的class可以看作只是一个语法糖,它的绝大部分功能,ES5 都可以做到,新的class写法只是让对象原型的写法更加清晰、更像面向对象编程的语法而已。

    • Class 的基本用法
    class Super {
        
      //构造方法
      constructor(x, y) {
        this.x = x;
        this.y = y;
      }
      //静态变量
      static classVar = [];
      //静态方法
      static classMethod() {
        return 'hello';
      }
       // 私有方法
      _priviteMethod(baz) {
          return this.x;
        }
      // 公有方法  
      toString() {
        return '(' + this.x + ', ' + this.y + ')';
      }
    }
    
    • Class 的继承

    Class 可以通过extends关键字实现继承,这比 ES5 的通过修改原型链实现继承,要清晰和方便很多。

    class ColorPoint extends Point {
      constructor(x, y, color) {
        super(x, y); // 调用父类的constructor(x, y)
        this.color = color;
      }
    
      toString() {
        return this.color + ' ' + super.toString(); // 调用父类的toString()
      }
    }
    

    相关文章

      网友评论

        本文标题:es6常用语法(二)

        本文链接:https://www.haomeiwen.com/subject/cwghhctx.html