清空和截短数组
最简单的清空和截短数组的方法就是改变 length 属性:
data:image/s3,"s3://crabby-images/7aa78/7aa78550a6a978a8579047cc50d7bc5f2a53f6bd" alt="1553764080158_1.png"
使用对象结构模拟命名参数
以前,当我们希望向一个函数传递多个参数时,可能会采用配置对象的模式:
data:image/s3,"s3://crabby-images/3f561/3f5618e2a798e0e13d030b50654dfe05243ea738" alt="1553764085269_2.png"
这是一个古老但是有效的模式,有了 ES2015 的对象结构,你可以这样使用:
data:image/s3,"s3://crabby-images/9b814/9b8141076dbf566b79cec0e4bcf77bbc59cc9d62" alt="1553764090181_3.png"
如果你需要这个配置对象参数变成可选的,也很简单:
data:image/s3,"s3://crabby-images/15d78/15d7805643d6e105cd23623c01fadde5cc72b0d7" alt="1553764094504_4.png"
数组的对象解构
使用对象解构将数组项赋值给变量:
data:image/s3,"s3://crabby-images/5d74d/5d74df2915b5d9006b30298b5a871ddfcd7672d9" alt="1553764099107_5.png"
注:本例中,2 为 split 之后的数组下标,country 为指定的变量,值为 US
switch 语句中使用范围
这是一个在 switch 语句中使用范围的例子:
data:image/s3,"s3://crabby-images/c7e5e/c7e5ed246f62b97b9669eaa036521ba098d78e8a" alt="1553764107908_6.png"
await 多个 async 函数
await 多个 async 函数并等待他们执行完成,我们可以使用 Promise.all:
data:image/s3,"s3://crabby-images/d4068/d4068bd4da61442674a913522efa7203a578b200" alt="1553764113163_7.png"
创建纯对象
你可以创建一个 100% 的纯对象,这个对象不会继承 Object 的任何属性和方法(比如 constructor,toString() 等):
data:image/s3,"s3://crabby-images/2db11/2db11de5be3a1ff595dd8d5f9a2548871d7ad430" alt="1553764120997_8.png"
格式化 JSON 代码
JSON.stringify 不仅可以字符串化对象,它也可以格式化你的 JSON 输出:
移除数组重复项
使用 ES2015 和扩展运算符,你可以轻松移除数组中的重复项:
data:image/s3,"s3://crabby-images/ec040/ec04089d8472ffbfd568bb1b7fae451dee071cbb" alt="1553764130410_10.png"
注:只适用于数组内容为基本数据类型
扁平化多维数组
使用扩展运算符可以快速扁平化数组:
data:image/s3,"s3://crabby-images/3be76/3be76348a11ec487f660c758da419cb7aa6a6602" alt="1553764135402_11.png"
不幸的是,上面的技巧只能适用二维数组,但是使用递归,我们可以扁平化任意纬度数组:
data:image/s3,"s3://crabby-images/c690f/c690fc876d95b094963ce4758685b2978622abe6" alt="1553764140361_12.png"
作者:黑马程序员前端与移动开发培训学院
首发:http://web.itheima.com/