javascript – 将ES6类分解为多个文件

前端之家收集整理的这篇文章主要介绍了javascript – 将ES6类分解为多个文件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
参见英文答案 > Splitting up class definition in ES 6 / Harmony2个
使用JavaScript“类”(我知道不是真正的类),可以通过将方法放在单独的文件中来分解大的定义,如下所示:
var Foo = function () {
  console.log('initializing foo');
};

Foo.prototype.render = require('./render');

但是对于ES6类,看起来语法排除了这种方法 – 似乎方法总是必须在类块中写成函数文字.

I tried this在6to5 REPL中:

class Foo {
  constructor() {
    console.log('initializing foo');
  }

  require('./render');
}

……但它错了.

作为示例,CoffeeScript的类语法允许我这样做:

class Foo
  constructor: ->
    console.log 'initializing foo'

  render: require './render'

ES6课程真的没办法做到这一点吗?

解决方法

类只是语法糖.所以你可以做到
class Foo {
  constructor() {
    console.log('initializing foo');
  }
}

Foo.prototype.render = require('./render');

或者你可以创建一个getter:

class Foo {
  constructor() {
    console.log('initializing foo');
  }

  get render() {
    return require('./render');
  }
}
原文链接:https://www.f2er.com/js/158761.html

猜你在找的JavaScript相关文章