文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JavaScript中如何使用or循环语句

2023-06-20 12:33

关注

这篇文章给大家分享的是有关JavaScript中如何使用or循环语句的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

for

这大概是应用最广的循环语句了吧,简单实用,且大多数时候性能还是在线的,唯一的缺点大概就是太普通,没有特色,导致很多人现在不愿用它。

const array = [4, 7, 9, 2, 6];for (let index = 0; index < array.length; index++) {    const element = array[index];    console.log(element);}// 4, 7, 9, 2, 6

for...in

for...in 语句可以以任意顺序遍历一个对象的除 Symbol 以外的可枚举属性。

const temp = {name: "temp"};function Apple() {    this.color = 'red';}Apple.prototype = temp;const obj = new Apple();for (const prop in obj) {    console.log(`obj.${ prop } = ${ obj[prop] }`);}// obj.color = red// obj.name = temp

如果你只要考虑对象本身的属性,而不是它的原型,那么使用  getOwnPropertyNames() 或执行 hasOwnProperty() 来确定某属性是否是对象本身的属性。

const temp = {name: "temp"};function Apple() {    this.color = 'red';}Apple.prototype = temp;const obj = new Apple();for (const prop in obj) {    if (obj.hasOwnProperty(prop)) {        console.log(`obj.${ prop } = ${ obj[prop] }`);    }}// obj.color = red

当然,也可以用来遍历数组。

const arr = [1, 2, 3, 4, 5];for (const key in arr) {    console.log(key)}// 0,1,2,3,4

使用 for...in 可以遍历数组,但是会存在以下问题:

  1. index 索引为字符串型数字(注意,非数字),不能直接进行几何运算。

  2. 遍历顺序有可能不是按照实际数组的内部顺序(可能按照随机顺序)。

所以一般不建议使用 for...in 来遍历数组。

for...of

for...of 语句在可迭代对象(包括 Array,Map,Set,String,TypedArray,arguments 对象等等)上创建一个迭代循环,调用自定义迭代钩子,并为每个不同属性的值执行语句。

const array = ['a', 'b', 'c'];for (const element of array) {    console.log(element);}// a// b// c

for...of 和 for...in 的区别:

Object.prototype.objCustom = function () { };Array.prototype.arrCustom = function () { };let iterable = [3, 5, 7];iterable.foo = 'hello';for (const key in iterable) {    console.log(key); // logs 0, 1, 2, "foo", "arrCustom", "objCustom"}// 0, 1, 2, "foo", "arrCustom", "objCustom"for (const key of iterable) {    console.log(key);}// 3, 5, 7

使用 for...of 遍历 Map 结构:

let nodes = new Map();nodes.set("node1", "t1")    .set("node2", "t2")    .set("node3", "t3");for (const [node, content] of nodes) {    console.log(node, content);}// node1 t1// node2 t2// node3 t3

可以看出,使用 for...of 遍历 Map 结构还是挺方便的,推荐使用!

总结

  1. 如果普通 for 循环用腻了,推荐使用 for...of 来替代。

  2. 这三种循环都可以使用 break 关键字来终止循环,也可以使用 continue 关键字来跳过本次循环。

  3. for...of 循环的适用范围最大。

感谢各位的阅读!关于“JavaScript中如何使用or循环语句”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯