ES2015部分新特性示例

ES2015部分新特性示

Arrow functions

var nums = [4,2,3,4]
nums.forEach((num, i)=> {
    console.log(num , i)
})

Block scoping with let. Compare to var

for (var i = 0; i <= 4; i++) {
    setTimeout( () => {
        console.log(i)
    }, 1000)
}
for (let i = 0; i <= 4; i++) {
    setTimeout( () => {
        console.log(i)
    }, 1000)
}

Default params

function test1(a, b, c=3) {
    console.log('Defualt vaule = ', a + b + c)
}
test1(1, 2)

Variadic function parameters

illustrate the use of reduce.

function sum(...nums) {
    console.log(nums.reduce( (acc, current) => {
        return acc + current
    }, 0 ))
}
sum(1, 2, 3, 4, 5)

Spread operator

var a = [1, 2, 3]
var b = [...a, 4, 5]
console.log(b)

Property shorthand

var c = 'ccc'
var d = 'ddd'
var e = { c, d}
console.log(e)
console.log(e.c)

Computed object keys

var name = 'somthing'
var object = {
    [name]: () => {
        return 'Hello'
    }
}
console.log(object.somthing())

Methods notation in objects

var methods = {
    foo() {
        console.log('foo')
    },
    bar() {
        console.log('bar')
    }
}
methods.foo()

Array destructing -> then swap-a-roo

var nums = [1, 2, 3]
var [one, two, three] = nums
console.log(one, two, three)
var [one, two] = [two, one]
console.log(one, two)

Object destructing, based on the name

var nums = { one: 1, two: 2, three: 3 }

var { one, three, two} = nums

console.log(one, two, three)

Classes, getter

class thing {
    constructor(_id) {
        this._id = _id
    }
    get id() {
        return this._id
    }
    showId(){
        return this._id
    }
}
var t = new thing(100)
console.log(t.id)
console.log(t.showId())

Generators

function* range(start, end) {
    while (start < end) {
        yield start
        start += 1
    }
}
for (let i of range(0, 10)) {
    console.log(i)
}

for-in for-of

var b = { a: 'tom'}
var a = ['a', b, 'c']
a.forEach( (item) => {
    console.log(item)
})


for (var index in a) {
    console.log(a[index]) //value   better to use on object
    //console.log(typeof(index)) //string
}

for (var value of a) {   // better ot use on array
    console.log(value)
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值