es6的一些常用新特性

1-变量let,const

  • 不存在变量提升
  • 同一个作用域下不能重复定义同一个名称
  • 有着严格的作用域
  • const声明的变量只可读,不可改变值,let可以。

2-箭头函数=>

  • 一行代码可以不写return
  • 不用重新绑定this指向

3-参数展开和扩展 ... 的运用

  • 收集剩余的参数
function show(a,b,...args){
    console.log(args)
}
  • 展开参数
function show (...args){}
show(12,5,6,7)
//...args = (12,5,6,7)

4-解构赋值

let [a,b,c] = [12,5,8]
let {a,b,c} = {a:12,b:5,c:8}

5-模板字符串拼接

var firstname="张"
var lastname="三"

//以前的字符串拼接
var Splicing="我的姓"+firstname+"名字叫"+lastname
console.log(Splicing)

//使用模板字符串拼接
var newSplicing=`我姓${firstname}名${lastname}`
console.log(newSplicing)

//模板字符串还支持表达式和函数
function add (x,y){
    return x+y;
}
var x=5;
var y=3;
var result=`5+3=${x+y}`;
console.log(result)   //5+3=8
var result2=`5+3=${add(x,y)}`
console.log(result)  //5+3=8

6-数据结构

  • set类似于数组,成员是唯一的,用法如下
const s new Set()
s.add(1).add(2).add(3).add(2)
console.log(s)

//利用set去重
var arr2 = [2,3,3,5,6,6,7,8,9,1,2,2,3,9]
var arr3 = [...new Set(arr2)]
console.log(arr3)
  • map类似于对象
const m = new Map()
m.set('name','amy').set('age',18)
console.log(m)
//可用for of遍历
for(let [key,value] of m){
    console.log(key,value)
}

7-数组一些方法操作

  • map()-映射-默认返回值是一个空数组,可以在回调函数中return对遍历的数组进行处理然后返回。
  • reduce()-汇总-可以算数组值的汇总,或者计算平均数,对数组计算。
  • filter()-过滤器-对数组的值进行过滤筛选
  • forEach()

8-字符串操作

  • startsWith("a")-获取以a开头的字符串值
  • endsWith("a")-获取以a结尾的字符串值

9-promise

  • 主要用于异步计算,可以将异步操作队列化,按照期望的顺序执行,返回符合预期的结果
  • promise是js中进行异步编程的新的解决方案
  • 从语法来讲promise是一个构造函数
  • 从功能上来说,promise对象用来封装异步操作并可获取结果
  • all()必须都完成才返回成功,race()有任意一个完成就算成功
promise.all([
    $.ajax({url:'url',dataType:'json'}),
    $.ajax({url:'url2',dataType:'json'})
]).then((res)=>{
    console.log('成功')
},()=>{
    console.log('失败')
})

10-generator

  • generator函数中间可以暂停,控制函数里代码执行,需要在函数前面加一个*号
  • next()暂停后继续向下执行
function *fun(){
    console.log('执行到a')
    yield
    console.log('执行到b')
}

11-async和await

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值