import 语句用于导入由另外一个模块导出的绑定。不管是否声明了 strict mode,导入的模块都运行在严格模式下。import语句不能在嵌入式脚本中使用。函数
import defaultExport from “module-name”;
import * as name from “module-name”;
import { export } from “module-name”;
import { export as alias } from “module-name”;
import { export1 , export2 } from “module-name”;
import { export1, export2 as alias2 , [...] } from “module-name”;
import defaultExport, { export [ , [...] ] } from “module-name”;
import defaultExport, * as name from “module-name”;
import “module-name”;
复制代码
将引用模块默认导出的名称。工具
要导入的模块。这一般是包含模块的 .js 文件的相对或绝对路径名,能够不包括 .js 扩展名。某些打包工具能够容许或要求使用该扩展;检查你的运行环境,只容许单引号和双引号的字符串。this
引用时将用做一种命名空间的模块对象的名称。url
要导入的导出名称spa
将引用指定的导入的名称。code
name 参数是“模块对象”的名称,它将用一种名称空间来引用导出。导出参数指定单个命名导出,而import * as name 语法导入全部导出。orm
这将 myModule 插入当前做用域,其中包含来自位于 /modules/my-module.js 文件导出的全部模块。对象
import * as myModule from ‘/modules/my-module.js’;
复制代码
在这里,访问导出意味着使用模块名称(在这种状况下为”myModule”)做为命名空间。例如,若是上面导入的模块包含一个doAllTheAmazingThings(),你能够这样调用:作用域
myModule.doAllTheAmazingThings();
复制代码
给定一个名为 myExport 的对象或值,它已经从模块 my-module 导出(由于整个模块被导出)或显式导出(使用 export 语句),将 myExport 插入到当前做用域。字符串
import { myExport } from ‘/modules/my-module.js’;
复制代码
将 foo 和 bar 插入当前做用域。
import { foo, bar } from ‘/modules/my-module.js’;
复制代码
导入时能够重命名导出,例如,将shortName 插入当前做用域。
import { reallyReallyReallyLongModuleExportName as shortName } from “/modules/my-module.js”;
复制代码
使用别名导入模块的多个导出。
import {
reallyReallyReallyLongModuleMemberName as shortName,
anotherLongModuleName as short
} form “/modules/my-module.js”;
复制代码
模块仅为反作用(中性词、无贬义含义)而导入,而不是导入模块中的任何内容,这将运行模块中的全局代码,但实际上不导入任何值。
import “/modules/my-module.js”
复制代码
在 default-export (不管是对象、函数、类等)有效时可用。而后能够使用 import 语句来导入这样的默认值。 最简单的用法是直接导入默认值:
import myDefault from “/modules/my-module.js”;
复制代码
也能够同时将 default 语法与上述用法(命名空间导入和命名导入)一块儿使用。在这种状况下,default 导入必须首先声明。
import myDefault, * as myModule from “/modules/my-module.js”;
复制代码
或者
import myDefault, { foo, bar } from “/modules/my-module.js”;
复制代码
从辅助模块导入以协助处理 AJAX DSON 请求。
function getJSON(url, callback){
let xhr = new XMLHttpRequest();
xhr.onload = function () {
callback(this.responseText)
};
xhr.open(‘GET’, url, true);
xhr.send();
}
export function getUserFulContents(url, callback){
getJSON(url, data => callback(JSON.parse(data)));
}
复制代码
import { getUserFulContents } from “/modules/file.js”;
getUserFulContents(‘http://www.example.com”,
data => { doSomethingUseful(data); } )
复制代码
strict mode 严格模式 嵌入式脚本