博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ES6转换为ES5
阅读量:6505 次
发布时间:2019-06-24

本文共 4698 字,大约阅读时间需要 15 分钟。

1.静态函数

  1.什么是静态函数

  静态函数最重要的就是不用创建一个实例变量就可以进行调用,在C++里面,无法访问this对象,

  而在JS里面由于js的this对象支持,是可以访问this对象,只是this对象有所不同

  2.ES6静态函数代码

classtestClass{    static staticFunc(){    console.log("instatic")    }}

将会被babel转换为:

"use strict";var _createClass = function () {    function defineProperties(target, props)    {        for (var i = 0; i < props.length; i++) {            var descriptor = props[i];            descriptor.enumerable = descriptor.enumerable || false;            descriptor.configurable = true;            if ("value" in descriptor)                descriptor.writable = true;            //利用defineProperty来创建函数            Object.defineProperty(target, descriptor.key, descriptor);        }    }    //创建函数,根据传入的数组创建成员函数和静态函数    return function (Constructor, protoProps, staticProps)    {        //注意这里,传入的是Constructor.prototype和Constructor        //所以可以区分是静态函数还是成员函数        if (protoProps)            defineProperties(Constructor.prototype, protoProps);        if (staticProps)            defineProperties(Constructor, staticProps);        return Constructor;    };}();function _classCallCheck(instance, Constructor) {    if (!(instance instanceof Constructor)) {        throw new TypeError("Cannot call a class as a function");    }}var testClass = function () {    function testClass() {        /*         *这是是为了保证这个class只能new出来,在usestrict模式下,this是undefined,         *正常模式下,this为window,也就是说我们这直接调用这个函数,_classCallCheck的时候将会抛出异常         **/        _classCallCheck(this, testClass);    }    _createClass(testClass, null, [{        key: "staticFunc",        value: function staticFunc() {            console.log("instatic");        }    }]);    return testClass;}();testClass.staticFunc();

2.=>符号

=>符号的出现是为了解决this作用域改变的问题

function test(){    this.x = 5;    this.f = function(){        console.log(this.x)    }}    let xx = new test();xx.f.call(this);

在上面的代码里面,本来是期望回调的时候log输出5的,但是此时call的时候this被修改为全局,所以将会产生错误,因为全局里面并没有x

function test(){    this.x = 5;    this.f = ()=>{        console.log(this.x)    }}let xx = new test();xx.f.call(this);

将代码修改为上面的代码后,即可正常输出5

"use strict";function test() {    var _this = this;     //通过创建一个临时的_this变量来规避this改变的问题    this.x = 5;    this.f = function () {        console.log(_this.x);    };}    var xx = new test();xx.f.call(undefined);     //在babel默认的use strict模式下,是不会有默认的全局this的

3.解构参数

/*这里只是单纯地翻译* var a=arr[0]* var b=arr[1]* var c=arr[2]* */let arr = [1,2,3];let [a, b, c] = arr;/** 这里也只是由编译器自动生成分割的语法,有点类似于erlang的语法* var head = 1;* var second = 2;* var tail = [3, 4]* */{    let [head,second, ...tail] = [1, 2, 3, 4];}{    /**     * 这里暂时不管yiled是怎么转换的,转换完的代码后:     * var first = _fibs[0]     * var second = _fibs[1]     * var three = _fibs[2]     * 还是自动生成与语法糖     */    function* fibs() {        var a = 0;        var b = 1;        while (true) {            yield a;            [a, b] = [b, a + b];        }    }    var [first, second, third, fourth, fifth, sixth] = fibs();}{    /*    * 跟之前的大同小异,    * var _foo$bar = { foo: “lorem", bar: "ipsum" };    * var bar = _foo$bar.bar;    * var foo = _foo$bar.foo;    * */    var { bar, foo } = { foo: "lorem", bar: "ipsum" };    function t(a){        if(a == 0 ){            return [1, 2, 3];        }        else{            return [];        }    }    let [a, b, c] = t(0);    let [d=1, e=2, f] = t(1);    console.log(d)}

4.默认参数,不定参数,扩展参数

/** 主要是利用arguments取得所有的参数,然后从1开始,把参数都取出来,如果是a, b,...tail则会从2开始*  for (var _len = arguments.length, needles = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {*   needles[_key - 1] = arguments[_key];*  }* */function containsAll(haystack,...tail) {    console.log(arguments.length)}containsAll(1, 2,3,4);//判断arguments的[0]是否为undefined//var a = arguments.length <= 0 || arguments[0] === undefined ? '11' : arguments[0];function containsAll2(a = '11'){    console.log(a)}containsAll2(2)

5.yield

/*//这个regeneratorRuntime估计是polyfill的东西var _marked = [fu].map(regeneratorRuntime.mark);function fu() {    var i;    //这里讲函数内部的变量声明在这里,然后利用闭包一直保持住这些变量的改变的改变,再通过switch来选择执行到那一段    //跟C++里面的无堆栈routine的实现比较相似    return regeneratorRuntime.wrap(function fu$(_context) {        while (1) {            switch (_context.prev = _context.next) {                case 0:                    i = 9;                    i++;                    _context.next = 4;                    return i;                case 4:                    i++;                    _context.next = 7;                    return i;                case 7:                case "end":                    return _context.stop();            }        }    }, _marked[0], this);}*/function *fu(){    let i = 9;    i++;    yield i;    i++;    yield i;}fu();fu();

 

转载于:https://www.cnblogs.com/linyilong3/p/5835964.html

你可能感兴趣的文章
linux下SVN不允许空白日志提交
查看>>
第2周第1课
查看>>
山寨c 标准库中的getline 函数
查看>>
shell时间
查看>>
pfSense book之2.4安装指南
查看>>
org.springframework.data.redis 一次连接获取特定key所有k-v(pipeline)
查看>>
[译稿]同步复制提议 2010-09
查看>>
windows 自动化目录大纲(各企业架构不一样,按需选择)
查看>>
我的友情链接
查看>>
【Visual C++】游戏开发笔记十三 游戏输入消息处理(二) 鼠标消息处理
查看>>
我的友情链接
查看>>
Java 使用 Redis
查看>>
JPA常用注解
查看>>
Java基础学习总结(1)——equals方法
查看>>
Maven学习总结(6)——Maven与Eclipse整合
查看>>
HTML5:理解head
查看>>
oracle
查看>>
java SpringUtil获取bean
查看>>
Centos6.4最小化安装系统初始化脚本
查看>>
赛门铁克开启“容灾即服务”时代
查看>>