美文网首页
class to es5

class to es5

作者: 薯条你哪里跑 | 来源:发表于2022-03-18 19:45 被阅读0次

1.Class

众所周知js是没有class的,但是es6却给了我们“类”的概念;
我们先写一个es6的类:

class TMP{
  constructor(){
    this.init()
  }
  init(){
    console.log("INIT")
  }
  static getName (){
    console.log("小鸟游六花")
  }
}

查看其转为ES5的代码,类其实是由原型链机制来实现的;将非静态属性绑定到类原型链上,静态属性绑定到类本身上,从而来实现class效果。

"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; 
      Object.defineProperty(target, descriptor.key, descriptor); 
    } 
  }
  return function (Constructor, protoProps, staticProps) { 
    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 TMP = function () {
  function TMP() {
    _classCallCheck(this, TMP);
    this.init();
  }
  _createClass(TMP, [{
    key: "init",
    value: function init() {
      console.log(“INIT”);
    }
  }], [{
    key: "getName",
    value: function getName() {
      console.log("小鸟游六花");
    }
  }],);

  return TMP;
}();

所以在我们使用TMP上的static的getName方法时不可将其实例化

new TMP.getName()   // 会报错 TypeError: TMP.getName is not a constructor
TMP.getName()  // 正确  输出 ("小鸟游六花"

扩展一下,下面代码会输出什么呢

(new TMP).getName()   // INIT   Uncaught TypeError: (intermediate value).getName is not a function
new TMP().init()    // INIT    INIT 
new TMP().getName()      // INIT    VM3425:1 Uncaught TypeError: (intermediate value).getName is not a function
new TMP.init()    // TMP.init is not a constructor

2.let & const

老生常谈,以下for循环中问你输出:

function test(){
    for(var i=0;i<3;i++){
      setTimeout(function(){
        console.log(i)
      },0)
    }
}
test() 

明显输出三个3,之后问你怎么做才能输出1、2、3;只需要利用let便可简单实现

function test(){
    for(let i=0;i<3;i++){
      setTimeout(function(){
        console.log(i)
      },0)
    }
}
test() 

那么转义成es5时是如何实现的呢?

function test(){
  var _loop = function _loop(i) {
    setTimeout(function () {
      console.log(i);
    }, 0);
  };
  for (var i = 0; i < 3; i++) {
    _loop(i);
  }
}
test() 

可以看到在函数test体内声明个函数表达式,在for内调用时传入i来实现。

相关文章

  • class to es5

    1.Class 众所周知js是没有class的,但是es6却给了我们“类”的概念;我们先写一个es6的类: 查看其...

  • es5实现class类

    es5没有类,只有构造函数。ES6新增了class,用于创建类。本文通过es5来实现es6的class(一个Ani...

  • JS 中继承的写法

    es5: es6: class 在原型上声明一个不是函数的属性:es5:Human.prototype.race ...

  • ES6 的知识点学习笔记(2) - class 静态方法 继承

    在之前的 ES5 中, 是没有类 (class) 的概念的,例子: ES5 构造函数 Person ES6 cla...

  • class

    Class ES5中的类使用ES5中的类特点:使用function来进行模仿的 实例 & 类 & Object的关...

  • Class 的继承 extend继承 es6继承基本用法

    Class继承基本用法 Class 可以通过extends关键字实现继承,这比 ES5 的通过修改原型链实现继承,...

  • es6 class理解

    es6 class 是es5 function的语法糖 class中的所有方法 对应了 function的原型链上...

  • 使用ES5实现ES6的Class

    ES5的寄生组合式继承 ES6的Class 关于Class的语法推荐看这里:es6.ruanyifeng.com/...

  • 19class的基本语法

    Class 是 es6 的语法糖,es5 也能通过其他方式实现 基础 Class 内部的方法不使用 functio...

  • javascript中的class

    ES5 定义构造函数 通过构造函数加属性,通过原型加方法: ES6 Class语法 class 实际上是语法糖,编...

网友评论

      本文标题:class to es5

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