5 模板字符串
ES6支持模板字符串,使得字符串的拼接更加的简洁、直观。
不使用模板字符串:
在ES5中字符串拼接通过【+】实现
let first = "张";
let last = "四";
let name = 'Your name is ' + first + ' ' + last + '.''
使用模板字符串:
ES6中使用反引号【``】来拼接字符串,使用【${}】来包含变量
let first = "张";
let last = "四";
let name = `Your name is ${first} ${last}.`;
6 模块化(Module) export和import
<!--使用 type="module" 属性告诉浏览器,这个 <script> 标签中的 JavaScript 代码是一个模块。
//浏览器会按照模块化的方式去加载和执行这段代码,包括解析依赖关系、异步加载等。模块具有自己的作用
域,模块内部的变量和函数不会污染全局作用域,也不会受到其他模块的影响-->
<script type="module">
</script>
6.1 export
模块是独立的文件,该文件内部的所有的变量外部都无法获取。如果希望获取某个变量,必须通过
export输出
// profile.js
export let firstName = 'Michael';
export let lastName = 'Jackson';
export let year = 1958;
或者用更好的方式:用大括号指定要输出的一组变量
// profile.js
let firstName = 'Michael';
let lastName = 'Jackson';
let year = 1958;
export {firstName, lastName, year};
除了输出变量,还可以输出函数或者类(class),
export function multiply(x, y) {
return x * y;
};
还可以批量输出,同样是要包含在大括号里,也可以用as重命名
function v1() { ... }
function v2() { ... }
export {
v1 as streamV1,
v2 as streamV2,
v2 as streamLatestVersion
};
export 命令规定的是对外接口,必须与模块内部变量建立一一对应的关系
main.js import profile.js文件
//profile.js
// 写法一
export let m = 1;
// 写法二
let m = 1;
export {m};
// 写法三
let n = 1;
export {n as m};
// 报错
export 1;
// 报错
let m = 1;
export m;
6.2 import
export定义了模块的对外接口后,其他JS文件就可以通过import来加载这个模块,
import命令接受一对大括号,里面指定要从其他模块导入的变量名,必须与被导入模块
( profile.js )对外接口的名称相同。
如果想重新给导入的变量一个名字,可以用as关键字,
import后的from 可以指定需要导入模块的路径名,可以是绝对路径,也可以是相对路径, .js路径可以
省略,如果只有模块名,不带有路径,需要有配置文件指定。
注意, import 命令具有提升效果,会提升到整个模块的头部,首先执行。(是在编译阶段执行的)
module的整体加载
除了指定加载某个输出值,还可以用(*)指定一个对象,所有的变量都会加载在这个对象上。
// 报错
export 1;
// 报错
let m = 1;
export m;
import {firstName, lastName, year} from './profile'; //使用相对路径或者绝对路径
function setName(element) {
element.textContent = firstName + ' ' + lastName;
}
import { lastName as surname } from './profile'
// circle.js。输出两个函数
export function area(radius) {
return Math.PI * radius * radius;
}
export function circumference(radius) {
return 2 * Math.PI * radius;
}
// main.js 加载在个模块
import { area, circumference } from './circle';
console.log('圆面积:' + area(4));
console.log('圆周长:' + circumference(14));
//上面写法是逐一指定要加载的方法,整体加载的写法如下。
import * as circle from './circle';
console.log('圆面积:' + circle.area(4));
注意,模块整体加载所在的那个对象(上例是 circle ),应该是可以静态分析的,所以不允许运行时
改变。
export default
之前的例子中,使用import导入时,都需要知道模块中所要加载的变量名或函数名,用户可能不想阅读
源码,只想直接使用接口,就可以用export default命令,为模块指定输出
其他模块加载该模块时, import 命令可以为该匿名函数指定任意名字。
export default也可以用于非匿名函数前。
下面比较一下默认输出和正常输出。
console.log('圆周长:' + circle.circumference(14));
import * as circle from './circle';
// 下面两行都是不允许的
circle.foo = 'hello';
circle.area = function () {};
// export-default.js
export default function () {
console.log('foo');
}
// import-default.js
import customName from './export-default';
customName(); // 'foo'
// 第一组
export default function crc32() { // 输出
// ...
}
import crc32 from 'crc32'; // 输入
// 第二组
export function crc32() { // 输出
// ...
};
import {crc32} from 'crc32'; // 输入
7 解构语法
7.1 数组的解构
7.1.1 数组解构的基本用法
const names = ["abc","cba","ccc"]
console.log(names); //[ 'abc', 'cba', 'ccc' ]
const [item1,item2,item3] = names
console.log(item1,item2,item3); //abc cba ccc
7.1.2 顺序解构
//数组解构中只想解构后面的元素
//比如说只想解构最后一个
const[,,itemz] = names
console.log(itemz); //ccc
### 7.1.3 解构出数组
//解构出一个元素,后面的元素放入一个新的数组中
const [itema,...newNames] = names //这里的...不是展开运算符,与函数的剩余参数比较相似
console.log(itema); //abc
console.log(newNames); // [ 'cba', 'ccc' ]
7.1.4 解构的默认值
//应用场景:比如用户要解构4个值,但是数组只有3个值,就可以用到默认值了。
const [itema,itemb,itemc,itemd = "aaa"] = names
console.log(itemd); //aaa
7.2 对象的解构
7.2.1 任意顺序
const obj = {
name : 'harry',
age:21,
height:1.98
}
//解构的无序性
let {age,height,name} = obj
console.log(name,age,height);//harry 21 1.98
7.2.2 重命名
const names = ["abc","cba","ccc"]
console.log(names); //[ 'abc', 'cba', 'ccc' ]
const [item1,item2,item3] = names
console.log(item1,item2,item3); //abc cba ccc
//数组解构中只想解构后面的元素
//比如说只想解构最后一个
const[,,itemz] = names
console.log(itemz); //ccc
//解构出一个元素,后面的元素放入一个新的数组中
const [itema,...newNames] = names //这里的...不是展开运算符,与函数的剩余参数比较相似
console.log(itema); //abc
console.log(newNames); // [ 'cba', 'ccc' ]
//应用场景:比如用户要解构4个值,但是数组只有3个值,就可以用到默认值了。
const [itema,itemb,itemc,itemd = "aaa"] = names
console.log(itemd); //aaa
const obj = {
name : 'harry',
age:21,
height:1.98
}
//解构的无序性
let {age,height,name} = obj
console.log(name,age,height);//harry 21 1.98
//给解构出的属性重写定义一个新的名称
let {name:newName} = obj
console.log(newName); //harry
7.2.3 默认值
//设置默认值
const {address = "南京市"} = obj
console.log(address);//南京市
const {sex:manOrWoman = '男'} = obj
console.log(manOrWoman); //男