import 语句用于导入从外部模块,另一个脚本等导出的函数,对象或原语。

注意:此功能目前无法在任何浏览器中实现。它在许多转换器中实现,例如 Traceur Compiler , Babel , Rollup 或 Webpack

语法EDIT

  1. import defaultMember from "module-name";
  2. import * as name from "module-name";
  3. import { member } from "module-name";
  4. import { member as alias } from "module-name";
  5. import { member1 , member2 } from "module-name";
  6. import { member1 , member2 as alias2 , [...] } from "module-name";
  7. import defaultMember, { member [ , [...] ] } from "module-name";
  8. import defaultMember, * as name from "module-name";
  9. import "module-name";
name
导入将会引用的对象的名称。。
member, memberN
将要导入的导出成员的名称。
defaultMember
将引用从模块默认导出的名称。
alias, aliasN
将引用命名导入的名称。
module-name
要导入的模块的名称。

描述EDIT

name 参数是将引用导出成员的名称。member参数指定独立成员,而name参数导入所有成员。如果模块导出单个默认参数,而不是一系列成员,name也可以是函数。
下面提供一些示例说明语法。

导入整个模块的内容。以下代码将myModule添加到当前作用域,其中包括所有导出绑定。

  1. import * as myModule from "my-module";

导入模块的单个成员。以下代码将myMember添加到当前作用域。

  1. import {myMember} from "my-module";

导入模块的多个成员。以下代码会将foo和bar都添加到当前作用域

  1. import {foo, bar} from "my-module";

导入整个模块的内容,其中一些被显式命名。
以下代码将myModulefoo,bar插入到当前作用域。注意,foomyModule.foo是完全相同的,barmyModule.bar也是如此。

  1. import MyModule, {foo, bar} from "my-module";

导入成员并指定一个方便的别名。以下代码将shortName添加到当前作用域。

  1. import {reallyReallyLongModuleMemberName as shortName} from "my-module";

导入整个模块 使用模块副作用,不导入任何绑定。

  1. import "my-module";

使用别名导入模块的多个成员。

  1. import {reallyReallyLongModuleMemberName as shortName, anotherLongModuleName as short} from "my-module";

导入默认值

可以导出默认选项,无论是一个对象,一个函数或一个 class。相对地, 也可以使用 import 导入默认成员。

最简单版本,直接导入默认。

  1. import myDefault from "my-module";

也可以使用上面提到的方式导入命名空间。

  1. import myDefault, * as myModule from "my-module";
  2. // myModule used as a namespace

或者导入已有命名的默认项。这两种情况下,默认导入项必须最先声明。

  1. import myDefault, {foo, bar} from "my-module";
  2. // specific, named imports

EDIT

范例EDIT

导入一个辅助文件以协助处理 AJAX JSON 请求。

  1. // --file.js--
  2. function getJSON(url, callback) {
  3. let xhr = new XMLHttpRequest();
  4. xhr.onload = function () {
  5. callback(this.responseText)
  6. };
  7. xhr.open("GET", url, true);
  8. xhr.send();
  9. }
  10. export function getUsefulContents(url, callback) {
  11. getJSON(url, data => callback(JSON.parse(data)));
  12. }
  13. // --main.js--
  14. import { getUsefulContents } from "file";
  15. getUsefulContents("http://www.example.com", data => {
  16. doSomethingUseful(data);
  17. });

规范EDIT

规范 状态 注解
ECMAScript 2015 (6th Edition, ECMA-262)
Imports
Standard Initial definition.
ECMAScript 2017 Draft (ECMA-262)
Imports
Draft  

浏览器兼容性EDIT

特性 Chrome Firefox (Gecko) Internet Explorer Opera Safari
基本支持 未实现[2] 未实现[1] 未实现 未实现 未实现
特性 Android Chrome for Android Firefox Mobile (Gecko) IE Mobile Opera Mobile Safari Mobile
基本支持 未实现 未实现 未实现 未实现 未实现 未实现

[1] 查看 bug 568953.

[2] 查看 Chromium bug 1569

[3]  "启用实验性JavaScript功能" 标记的背后

[4] See Safari Technical Preview 21 版本注释

import 语句用于导入从外部模块,另一个脚本等导出的函数,对象或原语。的更多相关文章

  1. 模块的四种形式、 import和from...import、 循环导入问题、模块的搜索路径、 python文件的两种用途

    目录 模块的四种形式 模块 模块的四种形式 import和from...import 循环导入问题 模拟问题的发生: 解决方案 模块的搜索路径 Python文件的两种用途 模块的四种形式 Nike推荐 ...

  2. Python3 第五周大纲(模块,导入方法、import本质,导入优化,模块的分类)

    1.定义: 模块:逻辑上组织python代码(变量.函数.类.逻辑:实现一个功能,本质是.py结尾的文件) 2.导入方法 import module_name,module_name2,...... ...

  3. Python中的import语句

    Python中的import语句是导入一个文件,这条语句主要做三件事: 1 通过一定的方式,搜寻要导入的文件: 2 如果需要,就编译这个文件: 3 运行这个文件 但是,需要注意的是,所有这三个步骤,都 ...

  4. Python中from … import …语句

    from - import -语句可以让你从模块中导入一个指定的部分到当前模块

  5. Python-学习-import语句导入模块

    简单的学习一下调用外部的模块文件. 在Python中,模块是一种组织形式,它将彼此有关系的Pyrhon 代码组织到一个个独立的文件当中,模块可以包含可执行代码,函数,和类或者是这些东西的组合. 当我们 ...

  6. Python import语句导入模块语法[转]

    Python import语句导入模块语法 社区推荐:掘金是国内最活跃的技术社区,我们每日有优质Python开发实例分享,海量python开源库推送.来掘金,和更多懂技术的小伙伴交流.   pytho ...

  7. 模块(import语句,from...import语句,_name_属性)

    1, 什么是模块? 模块就是一系列功能的集合体 模块分为四个通用的类别: 1), 使用python编写的.py文件(*****) 2), 已被编译为共享库或DLL的C或C++扩展 3), 把一系列模块 ...

  8. python import 导入两个模块同时有同一名称的方法如何调用 ?

    from moudule import *(这种方法不推荐) 一般不推荐使用"from 模块 import"这种语法导入指定模块内的所有成员,因为它存在潜在的风险. 比如同时导入 ...

  9. 模块之字节编译的.pyc文件---from.import语句

    字节编译的.pyc文件输入一个模块相对来说是一个比较费时的事情,所以Python做了一些技巧,以便使输入模块更加快一些.一种方法是创建 字节编译的文件 ,这些文件以.pyc作为扩展名.字节编译的文件与 ...

随机推荐

  1. JUC线程池之 线程池架构

    线程池的架构图如下: Executor 它是"执行者"接口,它是来执行任务的.准确的说,Executor提供了execute()接口来执行已提交的 Runnable 任务的对象.E ...

  2. 【python】class之类属性

    class Foo(object): x=1.5 foo=Foo() print foo.x#通过实例访问类属性 >>>1.5 print Foo.x #通过类访问类属性 >& ...

  3. !!!!!!!【unittest】unittest需要懂的的技术

    https://docs.python.org/2/library/unittest.html

  4. 动态修改css 规则

    页面引用了两个样式表: <link href="css/mui.min.css" rel="stylesheet" /> <link href ...

  5. selenium java-2 chrome driver与对应版本

    chrome driver下载地址:https://npm.taobao.org/mirrors/chromedriver driver与chrome的对应关系: 1.进入最新的driver,查看no ...

  6. linux&android PPP 相关知识

    Linux&Android PPP相关FAQ   目录 Linux&Android PPP相关FAQ.. 1 一.         文档说明... 3 二.         常见调试技 ...

  7. 解决npm下载包失败的问题

    在我朝,用npm直接从官方的镜像下载包,经常会出现网络超时下载失败的问题,具体原因大家都懂,我就不说了. 不过,这些都无法阻挡我们对知识的渴望,一下提供几种我在工作中的解决办法,希望能帮助你. 1.安 ...

  8. 掩膜操作手写+API(第二天)

    1.1首先是用到的理论知识: 上面是一个通用的公式,光知道上面写程序还是有点麻烦的,下面公式画的有点丑,可以表达我的观点. 1.2用到的知识点:可以边看程序边看用到的知识点: CV_Assert(); ...

  9. selenium自动化测试遇到的问题积累--持续积累中

    引言: 在做UI自动化测试过程中,总是会遇到各种问题,而解决问题总是会花费一些时间和心思,但是解决后对于自己就是一种成长,持续积累,当可能遇到的问题都被你遇到过,并且都知道解决办法,这就是一种经验的价 ...

  10. uva-10167-枚举

    题意:生日蛋糕上面有2N草莓,怎么切能够将蛋糕和草莓平分成俩份,直接枚举,A和B,草莓不能落在直线上 #include <iostream> #include <stdio.h> ...