当前位置: 首页 > news >正文

海口网站制作推广网上企业推广

海口网站制作推广,网上企业推广,重庆石桥铺网站建设,做外围什么网站有客户今天看到一个面试题, 让下面解构赋值成立。 let [a,b] {a:1,b:2} 如果我们直接在浏览器输出这行代码,会直接报错,说是 {a:1,b:2} 不能迭代。 看了es6文档后,具有迭代器的就一下几种类型,没有Object类型,…

今天看到一个面试题, 让下面解构赋值成立。

let [a,b] = {a:1,b:2}

如果我们直接在浏览器输出这行代码,会直接报错,说是 {a:1,b:2} 不能迭代。

 看了es6文档后,具有迭代器的就一下几种类型,没有Object类型,不过文档也解释为什么没有给Object加Iterator 接口,原因是 对象(Object)之所以没有默认部署 Iterator 接口,是因为对象的哪个属性先遍历,哪个属性后遍历是不确定的,需要开发者手动指定。本质上,遍历器是一种线性处理,对于任何非线性的数据结构,部署遍历器接口,就等于部署一种线性转换。不过,严格地说,对象部署遍历器接口并不是很必要,因为这时对象实际上被当作 Map 结构使用,ES5 没有 Map 结构,而 ES6 原生提供了。

原生具备 Iterator 接口的数据结构如下。

  • Array
  • Map
  • Set
  • String
  • TypedArray
  • 函数的 arguments 对象
  • NodeList 对象

所以,我们回头看这道面试题,是不是只要给这个{a:1,b:2}加上一个迭代器函数就可以了。

 let [a,b] = {a:1,b:2}

这里我们看下迭代器是什么使用的,在es6里有一个  Symbol.iterator 属性,只要有这个属性,那么这个数据结构就是可以遍历的。下面这个arr是一个Array类型,那么Array本身就带迭代属性,而解构就是把迭代的遍历器对象 的next()返回的value赋值给变量。

let arr = ['1', '2', 'c3];
let iter = arr[Symbol.iterator]();iter.next() // { value: '1', done: false }
iter.next() // { value: '2', done: false }
iter.next() // { value: '3', done: false }
iter.next() // { value: undefined, done: true }/* let [a,b,c] = arr;  所以说解构赋值就是 */let iter = arr[Symbol.iterator]();
let a = iter.next().value;
let b = iter.next().value;
let c = iter.next().value;

利用这一点我们可以这样写 

  let [a, b] = {a: 1,b: 2,[Symbol.iterator]() {var arr = Object.values(this);return arr[Symbol.iterator]()}}

优化 

Object.prototype[Symbol.iterator] = function() {var arr = Object.values(this);return arr[Symbol.iterator]()}let [a, b] = {a: 1,b: 2}

 

那么在这个基础上,我们在完成下面这个题,如果让 a 使用for...of...打印出a.data里的值

 let a = {data: [1,2,3,4,5,6]}for(let k of a){// 打印 1,2,3,4,5,6}
let a = {data: [1, 2, 3, 4, 5, 6]}a[Symbol.iterator] = function() {let _this = this;let index = 0return {next() {if (index < _this.data.length) {return {value: _this.data[index++],done: false}}return {value: undefined,done: true}}}}for (let k of a) {console.log(k)}

http://www.dinnco.com/news/61027.html

相关文章:

  • 西安网站建设企业搜索引擎营销的概念
  • 南宁seo网络推广seo推广收费标准
  • 湖南手机网站制作公司网络营销策划方案模板范文
  • 镇江手机网站制作万江专业网站快速排名
  • facebook海外推广石家庄关键词优化软件
  • 新网站一天做多少外链爱站工具包官网下载
  • 设计高端网站台湾永久免费加密一
  • 东莞网站排名优化公司十大免费软文推广平台
  • 用eclipse做网站网站快速有排名
  • 做木材生意的外贸网站软件培训
  • wordpress 做大网站企业策划推广公司
  • 网站设计与实现作业各大搜索引擎入口
  • 银川做网站公司西安seo外包平台
  • 如何自己做彩票网站成都seo论坛
  • 项目网手游广州优化营商环境条例
  • 哪个网站有学做吃的seo专员是什么职位
  • 泰安选择企业建站公司免费网上销售平台
  • 网站底部有很多图标镇江关键字优化品牌
  • 太原网站建设总部在哪推广软文范例大全500
  • 做诈骗网站windows优化大师是自带的吗
  • jsp做网站的书seo关键词优化要多少钱
  • 电子书推送网站怎么做seo网站推广软件
  • 商丘网站设计百度风云搜索榜
  • 网站如何生成静态推广普通话手抄报模板可打印
  • 郑州做网站推广湖南网站seo找行者seo
  • 扬州做网站需要多少钱产品线上推广渠道
  • 电商网站的二级怎么做seo推广优化服务
  • wordpress 隔行网站seo平台
  • 甘肃网站建设公司电话重庆网络推广专员
  • wordpress加入题注网站快速优化排名官网