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

成都网站开发培训wordpress 3 企业主题

成都网站开发培训,wordpress 3 企业主题,合肥做网站好的公司哪家好,电子商务网站建设与维护概述Iterator 特性: 统一的接口:无论是数组、字符串还是自定义对象,只要它们有默认的迭代器,就可以使用 for…of 循环进行遍历。可迭代对象:具有 [Symbol.iterator] 属性的对象被认为是可迭代的。[Symbol.iterator] 是一个…

Iterator 特性:

  • 统一的接口:无论是数组、字符串还是自定义对象,只要它们有默认的迭代器,就可以使用 for…of 循环进行遍历。
  • 可迭代对象:具有 [Symbol.iterator] 属性的对象被认为是可迭代的。[Symbol.iterator] 是一个方法,返回一个迭代器。
  • 迭代器对象:迭代器是一个具有 next() 方法的对象,该方法返回包含 value 和 done 属性的对象。value 是当前迭代的值,done 是一个布尔值,表示迭代是否完成。

for…of 循环特性:

  • 简洁的语法:使用 for…of 可以遍历可迭代对象中的每个元素,而不需要编写额外的迭代逻辑。
  • 自动迭代:for…of 循环自动调用迭代器的 next() 方法,获取下一个值。
  • 异常处理:可以在 for…of 循环中使用 try…catch 来捕获在迭代过程中抛出的异常。

1:使用 for…of 遍历数组

let numbers = [1, 2, 3, 4, 5];for (let number of numbers) {console.log(number); // 依次输出 1 到 5
}

2:使用 for…of 遍历字符串

let str = "Hello";for (let char of str) {console.log(char); // 依次输出 'H', 'e', 'l', 'l', 'o'
}

3:自定义迭代器

let myIterable = {[Symbol.iterator]: function* () {yield 1;yield 2;yield 3;}
};for (let value of myIterable) {console.log(value); // 依次输出 1, 2, 3
}

4:使用 for…of 与自定义迭代器

function* numberIterator(max) {let current = 1;while (current <= max) {yield current++;}
}for (let number of numberIterator(5)) {console.log(number); // 依次输出 1 到 5
}

5:使用 for…of 捕获异常

let iterable = [1, 2, 3, 4, 'error', 6];for (let item of iterable) {try {if (typeof item === 'string') {throw new Error('Invalid value');}console.log(item * 2); // 依次输出 2, 4, 6, 8} catch (e) {console.error(e.message); // 输出:Invalid value}
}

6:使用 Array.from 将可迭代对象转换为数组

let str = "Iterator";let arrayFromIterable = Array.from(str);
console.log(arrayFromIterable); // 输出:['I', 't', 'e', 'r', 'a', 't', 'o', 'r']

注意

兼容性:for…of 循环在现代浏览器和 Node.js 中得到支持,但一些旧的 JavaScript 环境可能不支持。
性能:对于大型集合,for…of 循环可能不如传统的 for 循环高效,因为每次迭代都需要调用迭代器的 next() 方法。

7:数组的 Symbol.iterator

let arr = [1, 2, 3];// 数组是可迭代对象,具有默认的 Symbol.iterator 属性
let iterator = arr[Symbol.iterator]();console.log(iterator.next()); // { value: 1, done: false }
console.log(iterator.next()); // { value: 2, done: false }
console.log(iterator.next()); // { value: 3, done: false }
console.log(iterator.next()); // { value: undefined, done: true }

8:字符串的 Symbol.iterator

let str = "abc";// 字符串也是可迭代对象
let strIterator = str[Symbol.iterator]();console.log(strIterator.next()); // { value: "a", done: false }
console.log(strIterator.next()); // { value: "b", done: false }
console.log(strIterator.next()); // { value: "c", done: false }
console.log(strIterator.next()); // { value: undefined, done: true }

9:手动使用 Symbol.iterator

let myObj = {items: [3, 5, 7],[Symbol.iterator]: function* () {for (let item of this.items) {yield item * 2; // 迭代器返回值的两倍}}
};let iterator = myObj[Symbol.iterator]();console.log(iterator.next()); // { value: 6, done: false }
console.log(iterator.next()); // { value: 10, done: false }
console.log(iterator.next()); // { value: 14, done: false }
console.log(iterator.next()); // { value: undefined, done: true }
http://www.yayakq.cn/news/367159/

相关文章:

  • 服装网站搭建计划书企业所得税怎么合理节税
  • 网站内存不足wordpress配置网络
  • 济南建站公司模板网页导航条制作教程
  • 爱站长工具综合查询青海网站建设加q5299丶14602做词
  • 商城网站开发需要多少钱网站验证码体验
  • 网站续费公司wordpress2018主题
  • 茶叶网站建设策划书关键字优化策略
  • 怎么样推广网站郑州比较好的男科医院有哪些
  • 一个网站数据库成都网站设计 常凡云
  • 百度智能建站系统中核待遇那么好为什么去的人少
  • 各大搜索引擎网站提交入口南通哪里有做网站的
  • 个人网站备案 各省制作天下网站
  • 网站的链接优化dw网站怎么做搜索
  • 上饶网站建设3ao cc专业a成都设计公司第一名
  • 网站托管免费上海公司网站建设方案
  • 网站开发要学些什么企业网站模板湖南岚鸿
  • 新河网站建设济南医院网站建设服务公司
  • 做网站开发教程网站做很久了百度没收录
  • 高端建站属于外包公司么dw网站建设的常用技术
  • 金华网站建设外包wordpress xrea
  • 建湖专业做网站的公司建筑人才网官网96877
  • 网站开发协助方案帝国cms 网站例子
  • 上海域邦建设集团网站知乎 拒绝 朋友 做网站
  • 哪个网站免费建站最好网站设计知名企业
  • 网站开发怎么写windows live writer wordpress
  • 开发app和微网站有哪些功能有效的网络编址方案有
  • 无锡工程建设监察支队网站wordpress 标签 边栏
  • 建站模板11个免费网站空间
  • 甘肃网站建设开发企业网站一般多少钱
  • lol网站怎么做点击器原理