ES6-变量的结构赋值之应用

栏目: JavaScript · 发布时间: 5年前

内容简介:相信很多小伙伴都和我一样,虽然一直在学习ES6的新特性,但是却不能自如的将其应用到自己的代码中,这篇文章就来梳理下变量结构赋值的用途~上面的代码交换x和y的值,这样的写法不仅简洁,而且易读,语义非常清晰。函数只能返回一个值,如果要返回多个值,只能将他们放在数组或对象里返回。有了结构赋值,取出这些值就非常方便。

相信很多小伙伴都和我一样,虽然一直在学习ES6的新特性,但是却不能自如的将其应用到自己的代码中,这篇文章就来梳理下变量结构赋值的用途~

交换变量的值

let x = 1
let y = 2
[x, y] = [y, x]
复制代码

上面的代码交换x和y的值,这样的写法不仅简洁,而且易读,语义非常清晰。

从函数返回多个值

函数只能返回一个值,如果要返回多个值,只能将他们放在数组或对象里返回。有了结构赋值,取出这些值就非常方便。

// 返回一个数组
function example() {
    return [1, 2, 3]
}
let [a, b, c] = example()
复制代码
// 返回一个对象
function example() {
    return {
        foo: 1,
        bar: 2
    }
}

let {foo, bar} = example()
复制代码

函数参数的定义

结构赋值可以方便地将一组参数与变量名对应起来

// 参数是一组有次序的值
function f([x, y, z]) {...}
f([1, 2, 3])
复制代码
// 参数是一组无次序的值
function f({x, y, z}) {...}
f({z: 3, y: 2, z: 1})
复制代码

提取JSON数据

结构赋值对提取JSON中的对象尤其有用

let jsonData = {
    id: 42,
    status: "OK",
    data: [213, 232]
}
let {id, status, data: number} = jsonData

console.log(id: status, number) // 42, "OK", [867, 5309]
复制代码

上面的代码可以快速提取json数据的值

函数参数的默认值

jQuery.ajax = function (url, {
    async = true,
    beforeSend = function () {},
    cache = true,
    complete = function () {},
    crossDomain = false,
    global = true,
    // ... more config
}) {
    // ... do stuff
}
复制代码

指定参数的默认值,这样就避免了在函数体内再写 var foo = config.foo || 'default foo'; 这样的语句。

变量map结构

任何部署了Iterator接口的对象都可以用for...of 遍历循环。Map结构原生支持Iterator接口,配合变量的结构解构赋值获取键名和键值就非常方便。

var map = new Map()
map.set('first', 'hello')
map.set('second', 'word')

for (let [key, value] of map) {
    console.log(key + 'is' + value)
}
// first is hello
// second is world
复制代码

如果只想获取键名,或者只想获取键值,可以写成下面这样

// 获取键名
for (let [key,] of map) {
    // ...
}

// 获取键值
for (let [,value] of map) {
    // ...
}
复制代码

输入模块的指定方法

加载模块时,往往需要指定输入的方法,解构赋值使得输入语句非常清晰。

const {SourceMapConsumer, SourceNode} = require("source-map")
复制代码

以上的使用方法需要在工作中刻意使用练习,如不然还是很难真正的掌握:blush::blush::blush:-告诫自己,哈哈哈~


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Java并发编程实战

Java并发编程实战

Brian Goetz、Tim Peierls、Joshua Bloch、Joseph Bowbeer、David Holmes、Doug Lea / 童云兰 / 机械工业出版社华章公司 / 2012-2 / 69.00元

本书深入浅出地介绍了Java线程和并发,是一本完美的Java并发参考手册。书中从并发性和线程安全性的基本概念出发,介绍了如何使用类库提供的基本并发构建块,用于避免并发危险、构造线程安全的类及验证线程安全的规则,如何将小的线程安全类组合成更大的线程安全类,如何利用线程来提高并发应用程序的吞吐量,如何识别可并行执行的任务,如何提高单线程子系统的响应性,如何确保并发程序执行预期任务,如何提高并发代码的性......一起来看看 《Java并发编程实战》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

在线进制转换器
在线进制转换器

各进制数互转换器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具