我在上一个项目中开始使用es2015和babel.当我尝试做import
或export
在if
条件内时,我有一个错误'import' and 'export' may only appear at the top level
.我看到了很多这样的情况require
,但它与es2015模块配合使用效果不错.这种限制有什么理由吗?
JavaScript在ES6模块上执行静态分析.这意味着您无法动态执行导入或导出.有关更多信息,请阅读本文的第4.2节:
模块的结构是静态的意味着您可以在编译时确定导入和导出(静态) - 您只需要查看源代码,您不必执行它.
这种方法有很多原因,其中一些原因是为未来的功能准备JavaScript,这些功能依赖于源文件可静态分析的能力,即宏和类型(在前面提到的文章中讨论过).
关于该主题的另一篇有趣的 文章提到循环依赖和快速查找作为原因.
______
如果要export
在模块的某个嵌套块中执行,请重新考虑如何编写模块并公开其API /内部,因为几乎肯定不需要.如果您当前正在require
ES5代码中的嵌套块中使用模块,则同样如此.为什么不在require
/ import
在模块的顶部并在嵌套块中使用它们的API /内部?至少从可读性的角度来看,这种方法的主要优点是,您可以了解模块的依赖关系,而无需扫描其require
调用源.