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

海口网站制作推广企业网站建设方案模板

海口网站制作推广,企业网站建设方案模板,代理办公司注册大概多少钱,.net做网站今天看到一个面试题, 让下面解构赋值成立。 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.yidumall.com/news/67269.html

相关文章:

  • 有哪些做汽配的网站阿里云域名注册流程
  • 网站设计深圳百度竞价排名名词解释
  • 做网站需要多大空间淘宝关键词搜索工具
  • 做汽车团购的网站建设网站服务器ip查询
  • wordpress调用最近发布的文章关系网站优化公司
  • 宁波网站建设软件开发谷歌搜索入口中文
  • 商业设计网站有哪些武汉建站公司
  • 网站开发维护公司网站seo推广多少钱
  • 网站建设需要哪些技术商铺营销推广方案
  • 用易语言做抢购网站软件长沙正规seo优化公司
  • 专门做评测的网站百度极速版推广员怎么申请
  • 爱网站大全aso榜单优化
  • 公司起名查询厦门谷歌seo公司
  • 徐州金网网站建设哈尔滨百度搜索排名优化
  • 流程图制作网站网站建设服务商
  • 网站的架构与建设aso优化排名违法吗
  • 个人性质网站徐州seo顾问
  • 网站怎么能在百度搜到综合查询
  • 网站建设专家今日网站收录查询
  • 网站建设分为哪几个阶段网络整合营销策划书
  • 江西网站建设开发四川网络推广推广机构
  • 品网站建设公司百度seo关键词优化
  • 网站开发和维护微信软文怎么写
  • 腾讯云wed服务器做网站软文云
  • 北京住房城乡建设部网站首页怎么制作小程序
  • 哪个网站做线路攻略做得好湖南网站建设营销推广
  • 连云港建设局官方网站什么文案容易上热门
  • 山东青岛网站制作公司刷移动关键词优化
  • 做外贸去哪些网站找老外免费网站制作成品
  • 济南新站seo外包怎么建立网站的步骤