ES6 三个点新语法:数组元素的 rest / spread ,与对象属性的 rest / spread

更新日期: 2018-03-24 阅读次数: 4226 分类: Javascript

今天在看微信小程序 zanui 的 field 组件代码时,发现一个新的语法,即三个点:

<template
      is="zan-field"
      data="{{ ...config.base.name, value }}"></template>

其中的 config.base.name 是个对象,类似于

name: {
	focus: true,
	title: '收货人',
	placeholder: '名字'
}

如果不加这三个点就会报错

 Bad attr `data` with message
<template
	is="zan-field"
> 11 |       data="{{ config.base.name }}"></template>

第一次见此写法,查了一下才发现是 ES6 的新语法:Object rest and spread properties

需要注意的是对象的 rest / spread 属性只在 V8 v6.0.75+ 和 Chrome 60+ 版本以上才支持。

数组 rest elements 示例

const numbers = [1, 2, 3, 4];
=> undefined
const [a, ...b] = numbers;
=> undefined
a
=> 1
b
=> [ 2, 3, 4 ]

数组 spread elements 示例

const new_numbers = [a, ...b];
=> undefined
new_numbers
=> [ 1, 2, 3, 4 ]

对象的 rest properties 示例

const person = { 
..     firstName: 'Zhongwei', 
..     lastName: 'Sun', 
..     country: 'China', 
..     state: 'Shandong', 
.. };
=> undefined
const { firstName, lastName, ...rest } = person;
=> undefined
firstName
=> 'Zhongwei'
rest
=> { country: 'China', state: 'Shandong' }

对象的 spread properties 示例

const new_person = { firstName, lastName, ...rest };
=> undefined
new_person
=> { firstName: 'Zhongwei',
  lastName: 'Sun',
  country: 'China',
  state: 'Shandong' }

关于作者

我是来自山东烟台的一名开发者,喜欢瞎折腾,顺便记记笔记。有敢兴趣的话题,欢迎加微信 zhongwei 聊聊。 白天工地搬砖,晚上哄熊孩子,可能回复有点慢,见谅。 查看更多联系方式

相关文章

爱评论不评论

近期节日

2019年10月22日 世界传统医药日
2019年10月24日 霜降
2019年10月24日 联合国日
2019年10月31日 世界勤俭日
2019年11月01日 万圣节
2019年11月08日 立冬
2019年11月08日 中国记者日
2019年11月10日 世界青年节
2019年11月11日 光棍节,双十一购物节
2019年11月14日 世界糖尿病日
2019年11月17日 国际大学生节
2019年11月20日 国际儿童日
查看更多节日