博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ES6-变量的解构赋值之应用
阅读量:6870 次
发布时间:2019-06-26

本文共 1656 字,大约阅读时间需要 5 分钟。

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

交换变量的值

let x = 1let 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} = jsonDataconsole.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")复制代码

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

转载于:https://juejin.im/post/5cda7458e51d453b6d4d144c

你可能感兴趣的文章
iPhone开发之object c基础一定义接口
查看>>
Linux下清除磁盘分区及残留raid信息
查看>>
如何确认第二个sskgslcas就是获得Buffer Pin锁
查看>>
在Eclipse中配置tomcat
查看>>
Python基础
查看>>
springboot加载顺序
查看>>
python chapter 学习之序列
查看>>
我的友情链接
查看>>
Linux下如何知道自己外网的IP
查看>>
GlusterFS的基础应用
查看>>
DRBD+Heartbeat
查看>>
Ubuntu下vsftpd安装和配置
查看>>
IT运维之Linux服务器监控方案
查看>>
ORA-09925: Unable to create audit trail file Linux-x86_64
查看>>
安全存储专家usse
查看>>
pthon socket之SocketServer
查看>>
MySQL数值类型
查看>>
TCP、UDP下的套接字编程
查看>>
jboss7-的默认系统日志
查看>>
python中的多进程和多线程
查看>>