作者:mobiledu2502909217 | 来源:互联网 | 2023-01-26 17:11
我有一些功能,我想将它们保存在外部js文件中.例如.
在functions.js中
var double = function(x) {
return x + x;
}
export { double };
然后在我的主要js文件中:
import double from './functions';
...
double(2)
我收到此错误:
Uncaught TypeError: (0 , c.default) is not a function
at bundle.min.js:44
当我读到44行时:
(0, _functions2.default)(2);
有什么想法吗?我错过了什么?
1> RyanZim..:
您将默认和命名导出混淆.
如果export { double }
你必须import { double } from './functions';
如果您只有一个导出,则最好使用默认导出:
export default double;
然后你可以 import double from './functions':
原因是命名导出允许您仅导入模块的一部分.例如:
export function add (a, b) { return a + b; }
export function subtract (a, b) { return a - b; }
然后你可以import { add } from './math.js';
不导入subtract
.
但是,如果仅从模块导出一个函数,则默认导出更方便.