如何在ecmascript-6中导入模块
How to import modules in ecmascript-6?
我想在ecma脚本6中将不同的模块导入到我的模块中。例如:
import rest from 'rest';
export function client() {
// some logic
}
如果我将导入语句更改为经典:
var rest = require('rest');
一切都很好。有什么想法吗?
我不是专家,但import
在很多方面与require
相似,但关键区别在于:
-
您可以使用
import
导入选择性项(猜测这接近python),但使用require
,您只能将单个模块导出为命名空间,其他都是它的子模块。 -
第二,
require
更像是node.js的东西(尽管你可以使用browserify将其引入浏览器),但import
现在是ES6的原生功能,即支持ES6的浏览器,import
可以使用
lukehoban的es6功能的例子来重新执行我的第一点:
// lib/math.js
export function sum(x, y) {
return x + y;
}
export var pi = 3.141593;
// app.js
import * as math from "lib/math";
alert("2π = " + math.sum(math.pi, math.pi));
// otherApp.js
import {sum, pi} from "lib/math";
alert("2π = " + sum(pi, pi));
//Some additional features include export default and export *:
// lib/mathplusplus.js
export * from "lib/math";
export var e = 2.71828182846;
export default function(x) {
return Math.log(x);
}
// app.js
import ln, {pi, e} from "lib/mathplusplus";
alert("2π = " + ln(e)*pi*2);
这是我的问题的答案,但如果你想知道如何导入其他文件,请参考用户@mido给出的答案,例如查看此页面:http://www.2ality.com/2014/09/es6-modules-final.html
因此,@Felix King的评论引导我找到了正确的答案。正如Felix所建议的,rest模块并没有默认的导出功能,所以应该像这样导入:
import * as rest from 'rest';
所以它取决于一个模块,它是如何编写的。例如,包含在rest中的"mime"拦截器模块可以包含在:中
import mime from 'rest/interceptor/mime';
相关文章:
- 通过Webpack导入模块中的图像
- Javascript:导入模块是否会更改其中字符串的编码
- 无法导入模块:您可能需要一个合适的加载程序
- 导入模块失败's css文件
- RequireJS:模块函数是每次导入模块时执行还是第一次执行
- 当未定义默认导出时,从“模块”导入模块是什么,为什么它与将 * 导入为模块不同
- Chrome Javascript 源转换导入模块名称
- ES6:从URL导入模块
- 如何在ecmascript-6中导入模块
- 正在从github导入模块以进行本机反应
- ES6导入模块作为对象
- 在导入模块中使用主.js的功能
- 如何让ES6/2015导入/模块在浏览器中工作
- Angular2, typescript peer无效,不能导入模块
- SyntaxError:导入模块Node.js时的意外标识符
- 如何访问导入模块的其他功能中的道具
- node.js和浏览器代码重用:将常量导入模块
- 导入模块只是为了运行它
- 在哪里安装 Java 程序中使用的导入模块
- 访问 JS 中导入模块中的私有函数