首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Javascript es6类语法模式

Javascript es6类语法模式
EN

Stack Overflow用户
提问于 2016-11-10 21:02:04
回答 1查看 144关注 0票数 0

我正在研究一个节点模块,我希望继续使用es6类语法来保持样式的一致性,但我发现这种模式无法重现:

代码语言:javascript
运行
复制
const proto = module.exports = function(options) {
    man.opts = options || {};
    function man(sentence) {
        man.say(sentence);
    }

    man.__proto__ = proto;
    man.age = 29;
    man.say = function(sentence) {
        console.log(sentence);
    };
    return man;
};

这个函数的奇怪之处在于,我可以将它称为标准构造函数,并使用他的方法和道具获取一个人,但我也可以将man作为函数调用,并得到与调用他的方法"say“相同的结果。基本上,man('text')产生与man.say(‘text’)相同的效果;我如何使用es6类语法重新创建这个模式?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-10 21:46:35

基本上,man('text')产生了与man.say('text')相同的效果

最好不要使用那种模式。

如何使用es6类语法重新创建此模式?

您可以使用类似于Function的方法

代码语言:javascript
运行
复制
export default class {
    constructor(options) {
        const man = sentence => this.say(sentence);
        Object.setPrototypeOf(man, new.target.prototype);

        man.opts = options || {};
        man.age = 29;

        return man;
    }
    say(sentence) {
        console.log(sentence);
    }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40536935

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档