es6 Module语法
export 命令
1、概念
export用于定义要输出的变量(let、var、const、function、class),定义的变量与值是动态绑定关系。
2、命令格式
1、 export 变量定义
2、 export { 变量名 [ as 另名} ,…}
3、 export default 匿名定义
export default 匿名定义
匿名定义本质上是采用 default 为名称,与上面2个的区别是在加载时可以不用写大括号还能自定义名称。
import命令
1、 概念
import用于加载export模块
2、 命令格式
1、 import { 变量名 [as 别名}} from “文件路径”
2、 import * as 别名 from “文件路径”(用于整体加载)
3、 import 变量名 from “文件路径”(用于加载匿名变量)
export与import的复合写法
1、 概念
先import加载,然后在export定义。
export {…} from “文件路径”;
等同于
import {…} from “文件路径”;
export {…}
1、 整体输出
export * from “文件路径”;
2、 别名输出
export { xxx as ddd} from “文件路径”
3、 匿名输出
export { xxx as default} from “文件路径”
浏览器加载
<script type = “module” src=”…”>
或
<script type=”module”>
import {…} from “文件路径”;
</script>
注意:module 为异步defer 加载,也就是异步加载,然后页面渲染完成后执行脚本。
import() 函数
import函数是动态加载模块或非模块脚本并无静态连接,返回一个promise对象,可获取加载状态。
1、 格式
import(“文件路径”)
2、例子
import(…).then(module=>module.变量)
输出变量被当前参数转给then函数了。
例子:匿名与非匿名加载
// a.js
export default function (val) {
console.log(val);
} export function test(val) {
console.log(val);
}
<script type="module">
'use strict';
import print,{test} from "./a.js";
print("ss"); // 匿名
test("test"); // test
</script>
例子:整体加载
<script type="module">
'use strict';
import * as target from "./a.js";
target.test("test函数");
target.default("匿名变量")
</script>
例子:动态加载
// 浏览器并没有实现动态导入模块
<script type="module">
import("./a.js").then(module => {
module.test("你好");
module.default("哈哈");
});
</script>
es6 Module语法的更多相关文章
- ES6 module语法加载 import export
export:暴露,就是把接口暴露出去 import:引入,跟字面意思一样,引入接口 export {} export function demo(){} export var demo1; 这上面的 ...
- ES6常用语法
ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准.因为当前版本的ES6是在2015年发布的,所以又称ECMAScript 2015. 也就是说,ES6就是ES2015. ...
- JavaScript ES6 module 模块
在使用JavaScript开发大型项目时,模块开发概念是一个必须考虑的问题.其目的就是通过命名空间对各类业务对象进行一定的封装,防止命名冲突. 本篇着重介绍ES6 module中的export和imp ...
- ES6最新语法
ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准.因为当前版本的ES6是在2015年发布的,所以又称ECMAScript 2015. 也就是说,ES6就是ES2015. ...
- 深入 CommonJs 与 ES6 Module
目前主流的模块规范 UMD CommonJs es6 module umd 模块(通用模块) (function (global, factory) { typeof exports === 'obj ...
- ES6常用语法简介import export
ES6常用语法简介import export let与var用法区别 //var var a = []; for (var i = 0; i < 10; i++) { a[i] = functi ...
- ES6 | ES6新语法 在编码实践中的应用
本章探讨如何将 ES6 的新语法,运用到编码实践之中,与传统的 JavaScript 语法结合在一起,写出合理的.易于阅读和维护的代码. 多家公司和组织已经公开了它们的风格规范,本文的内容主要参考了 ...
- 通过ES6 Module看import和require区别
前言 说到import和require,大家平时开发中一定不少见,尤其是需要前端工程化的项目现在都已经离不开node了,在node环境下这两者都是大量存在的,大体上来说他们都是为了实现JS代码的模块化 ...
- 前端模块化IIFE,commonjs,AMD,UMD,ES6 Module规范超详细讲解
目录 为什么前端需要模块化 什么是模块 是什么IIFE 举个栗子 模块化标准 Commonjs 特征 IIFE中的例子用commonjs实现 AMD和RequireJS 如何定义一个模块 如何在入口文 ...
随机推荐
- mac本webstrom破解
之前忙着加班一直没搞,有时间解决一下 首先编辑hosts文件 https://jingyan.baidu.com/article/f3ad7d0f55154309c3345bdd.html Mac系统 ...
- ps入门学习
快捷键 打开 ctrl+O 切换显示窗口 ctrl+tab 隐藏工具栏和面板 tab 只隐藏面板不隐藏工具栏 shift+tab 切换屏幕模式 F 文件的新建与格式 1.新建文档Ctrl+N,存 ...
- 酒店管理系统ER图
- 流媒体协议(二):RTMP协议
一.概念与摘要 RTMP协议从属于应用层,被设计用来在适合的传输协议(如TCP)上复用和打包多媒体传输流(如音频.视频和互动内容).RTMP提供了一套全双工的可靠的多路复用消息服务,类似于TCP协议[ ...
- MyCat-schema.xml详解
一.概念与图示 schema.xml配置的几个术语与其关系图示: 二.schema 标签 schema 标签用于定义 MyCat 实例中的逻辑库,如: <schema name="US ...
- [Swift]LeetCode10. 正则表达式匹配 | Regular Expression Matching
Given an input string (s) and a pattern (p), implement regular expression matching with support for ...
- [Swift]LeetCode80. 删除排序数组中的重复项 II | Remove Duplicates from Sorted Array II
Given a sorted array nums, remove the duplicates in-place such that duplicates appeared at most twic ...
- [Swift]LeetCode748. 最短完整词 | Shortest Completing Word
Find the minimum length word from a given dictionary words, which has all the letters from the strin ...
- ubuntu(版本14.04)部署Core环境
遇到问题: 参照官方文档敲完命令之后 出现了提示的问题Unable to lpcate package... ,随后参照官方文档解决方案,又出现了如下问题: 提示找不到依赖的Runtime,在尝试过很 ...
- web开发中获取的各种高度和宽度
前端开发中经常需要获取页面还有屏幕的高度和宽度进行计算,此文即介绍如何用 JavaScript 还有 jQuery 获取这些尺寸. 1.简介 一个页面显示在浏览器内,浏览器又放置在屏幕窗口内,所以由里 ...