我有一个ExampleView类,应该是单例。在此类中,我有方法render,我想通过对象名称“ ExampleView”从另一个js文件中调用该方法。
这是代码:

import View from './view';

class ExampleView extends View {
    render() {
        return `<span>Test</span>`;
    }
}
export default new ExampleView(); //<- exporting as singleton and this object I try to get via it's name


首先,我应该从名称“ ExampleView”中检索以某种方式导出的单例对象ExampleView,然后调用方法render

class Test {
    getInstanceOfModuleByName(name) {
        //window[name].render();
    }
}


问题是我找不到从名称获取ExampleView实例的任何方法,但是我的ExampleView类需要为单例。

我知道我可以按照以下方式执行此操作,然后通过window['ExampleView'].render()调用它:

ExampleView = {
    render: function() {
        return `<span>Test</span>`;
    }
}


但是我真的需要用可调节的ES6来实现它。

您能解释一下我该怎么做吗?

最佳答案

填充全局范围不是ES6方式。我认为您可以对export这样操作

//
// Class definition
//
window.ExampleView = new ExampleView();

export default window.ExampleView;

关于javascript - 从JavaScript中的字符串获取导出的单例实例,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/58709871/

10-09 22:17