gy1*_*340 4 javascript ecmascript-6
我已经阅读了 MDN 的文档,好吧,主要是关于新模块功能的好处,让我感到困惑的是关于 的小事情export,现在,让我们看看:
当我
export function foo(x) {
return x * x;
}
Run Code Online (Sandbox Code Playgroud)
或者
export const foo = (x) => {
return x * x
}
Run Code Online (Sandbox Code Playgroud)
两者都有效;
但如果
const foo = (x) => {
return x * x
}
export foo // failed
Run Code Online (Sandbox Code Playgroud)
我知道这里应该是export {foo},但是,为什么呢?有什么区别,那应该是工作。很高兴听到一些精灵的想法。
ES 模块仅支持几种语法变体,以便进行静态分析。
根据参考,变化是:
export { name1, name2, …, nameN };
export { variable1 as name1, variable2 as name2, …, nameN };
export let name1, name2, …, nameN; // also var, function
export let name1 = …, name2 = …, …, nameN; // also var, const
export default expression;
export default function (…) { … } // also class, function*
export default function name1(…) { … } // also class, function*
export { name1 as default, … };
export * from …;
export { name1, name2, …, nameN } from …;
export { import1 as name1, import2 as name2, …, nameN } from …;
Run Code Online (Sandbox Code Playgroud)
export foo不在其中。它不受支持且无法使用。