在ES6模块中按字符串访问导出的函数

时间:2015-04-09 12:50:50

标签: module export ecmascript-6 babeljs

请考虑以下事项:

exports['handleEvent']('event');

export function handleEvent(event) {
  // do something with `event`
}

这在使用babel来转换节点模块时有效,因为它将所有内容都粘贴在exports对象上。在vanilla ES6中是否有出口对象的概念?我希望能够使用其名称字符串调用方法。

我想到的一件事就是将所有功能都粘贴在一个对象上并单独导出它们。另一个选择是使用一些邪恶的评估东西。是否有任何标准方法可以通过字符串访问当前模块中的ES6导出?

1 个答案:

答案 0 :(得分:3)

我不太确定我会跟着......

以下是ES6模块导入+导出的几个示例。它们中的任何一个都与您正在寻找的相匹配吗?

示例1

制片:

export function one() { return 1 };
export function two() { return 2 };

消费者:

import {one, two} from 'producer';

one();
two();

示例2

制片:

export function one() { return 1 };
export function two() { return 2 };

消费者:

import * as producer from 'producer';

producer.one(); // or producer['one']()
producer.two();

示例3

制片:

export default {
  one() { return 1 },
  two() { return 2 }
};

消费者:

import producer from 'producer';

producer.one(); // or producer['one']()
producer.two();

示例4

制片:

export default {
  one() { return 1 },
  two() { return 2 }
};

消费者:

import {one, two} from 'producer';

one();
two();

示例5

制片:

export default function() { return 1 };
export function two() { return 2 };

消费者:

import one, {two} from 'producer';

one();
two();