小言_互联网的博客

ES6新语法学习笔记

267人阅读  评论(0)
1、变量声明

以前声明变量使用关键词:var
但使用它声明的变量会是全局变量。如以下代码:

现使用关键词:let
声明的变量为局部变量

使用关键词:const
声明为不可变类型,对应java中final类型。

2、字符串

新增三大函数:

  1. includes():返回布尔值,表示是否找到了参数字符串。
  2. startsWith():返回布尔值,表示参数字符串是否在原字符串的头部。
  3. endsWith():返回布尔值,表示参数字符串是否在原字符串的尾部。
3、解构表达式

声明一个数组[1,2,3]
以前只能通过角标获取某数组的值
新语法可如下获取:

针对对象的赋值一样适用。如下:

4、函数优化

1)函数参数默认值
旧版本:

function add(a , b) {
// 判断b是否为空,为空就给默认值1
b = b || 1;
return a + b;
}
// 传一个参数
console.log(add(10));

ES6语法:

function add(a , b = 1) {
return a + b;
}
// 传一个参数
console.log(add(10));

2)箭头函数
ES6中定义函数的简写方式:
①一个参数时:

var print = function (obj) {
console.log(obj);
}

简写为:

var print2 = obj => console.log(obj);

②多个参数:

// 两个参数的情况:
var sum = function (a , b) {
return a + b;
}

// 简写为:
var sum2 = (a,b) => a+b;
代码不止一行,可以用{}括起来
var sum3 = (a,b) => {
return a + b;
}

③对象的函数属性简写
比如一个Person对象,里面有eat方法:

let person = {
name: "jack",
// 以前:
eat: function (food) {
console.log(this.name + "在吃" + food);
},
// 箭头函数版:
eat2: food => console.log(person.name + "在吃" + food),// 这里拿不到this
// 简写版:
eat3(food){
console.log(this.name + "在吃" + food);
}
}

④箭头函数结合解构表达式
比如有一个函数:

const person = {
name:"jack",
age:21,
language: ['java','js','css']
}
function hello(person) {
console.log("hello," + person.name)
}
//如果用箭头函数和解构表达式
var hi = ({name}) => console.log("hello," + name);

5、map和reduce(数组)

1)map
map():接收一个函数,将原数组中的所有元素用这个函数处理后放入新数组返回。
举例:有一个字符串数组,我们希望转为int数组

let arr = ['1','20','-5','3'];
console.log(arr)
arr = arr.map(s => parseInt(s));
console.log(arr)


2)reduce
reduce():接收一个函数(必须)和一个初始值(可选),该函数接收两个参数:
第一个参数是上一次reduce处理的结果
第二个参数是数组中要处理的下一个元素
reduce()会从左到右依次把数组中的元素用reduce处理,并把处理的结果作为下次reduce的第一个参数。如果是第一次,会把前两个元素作为计算参数,或者把用户指定的初始值作为起始参数

6、promise

解释:可以理解为一个容器,里面保存着未来可能结束的事件(异步操作)。
语法:

const promise = new Promise(function(resolve, reject) {
// ... 执行异步操作
if (/* 异步操作成功 */){
resolve(value);// 调用resolve,代表Promise将返回成功的结果
} else {
reject(error);// 调用reject,代表Promise会返回失败结果
}
});

这样,在promise中就封装了一段异步执行的结果。
在异步执行完成之后可使用then方法继续进行操作。

promise.then(function(value){
// 异步执行成功后的回调
});

如果想要处理promise异步执行失败的事件,还可以跟上catch:

promise.then(function(value){
// 异步执行成功后的回调
}).catch(function(error){
// 异步执行失败后的回调
})
7、set和map

1)set
与数组类似,只能保存不同的元素,和java中的set集合相似。
构造函数:

// Set构造函数可以接收一个数组或空
let set = new Set();
set.add(1);// [1]
// 接收数组
let set2 = new Set([2,3,4,5,5]);// 得到[2,3,4,5]

普通方法:

set.add(1);// 添加
set.clear();// 清空
set.delete(2);// 删除指定元素
set.has(2); // 判断是否存在
set.keys();// 返回所有key
set.values();// 返回所有值
set.entries();// 返回键值对集合
// 因为set没有键值对,所有其keys、values、entries方法返回值一样的。
set.size; // 元素个数。是属性,不是方法。

2)map
本质是与Object类似的结构。不同在于,Object强制规定key只能是字符串。而Map结构的key可以是任意对象。
构造函数:

// map接收一个数组,数组中的元素是键值对数组
const map = new Map([
['key1','value1'],
['key2','value2'],
])
// 或者接收一个set
const set = new Set([
['key1','value1'],
['key2','value2'],
])
const map2 = new Map(set)
// 或者其它map
const map3 = new Map(map);

8、模块化

模块化则是将代码进行拆分,提高代码的复用性。
1)export
导出某个对象,如下定义为hello.js

export const util = {
    sum(a,b){
    	return a + b;
    }
}

export不仅可以导出对象,一切JS变量都可以导出。比如:基本类型变量、函数、数组、对象。
当要导出多个值时,还可以简写。比如我有一个文件:user.js:

var name = "jack"
var age = 21
export {name,age}

省略名称
上面的导出代码中,都明确指定了导出的变量名,这样其它人在导入使用时就必须准确写出变量名,否则就会出错。
因此js提供了default关键字,可以对导出的变量名进行省略
例如:

// 无需声明对象的名字
export default {
    sum(a,b){
   		return a + b;
    }
}

2)import
使用export命令定义了模块的对外接口以后,其他 JS 文件就可以通过import命令加载这个模块。
例如我要使用上面导出的util:

// 导入util
import util from 'hello.js'
// 调用util中的属性
util.sum(1,2)

要批量导入前面导出的name和age:

import {name, age} from 'user.js'
console.log(name + " , 今年"+ age +"岁了")
9、对象扩展
keys(obj);//获取对象的所有key形成的数组
values(obj);//获取对象的所有value形成的数组
entries(obj);//获取对象的所有key和value形成的二维数组。格式:[[k1,v1],[k2,v2],...]
assian(dest, ...src) ;//将多个src对象的值 拷贝到 dest中(浅拷贝)。
10、数组扩展
find(callback);//把数组中的元素逐个传递给函数callback执行,如果返回true,则返回该元素
findIndex(callback);//与find类似,不过返回的是品牌到的元素的索引
includes(callback);//与find类似,如果匹配到元素,则返回true,代表找到了。

转载:https://blog.csdn.net/weixin_43867589/article/details/101194931
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场