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

律师在哪个网站做推广好seo推广排名软件

律师在哪个网站做推广好,seo推广排名软件,企业所得税优惠政策2020,网站后台维护教程你好,我是沐爸,欢迎点赞、收藏、评论和关注。 在 JavaScript 中,for...in 和 for...of 是两种用于遍历数组(或其他可迭代对象)的循环语句,但它们之间存在显著的差异。 一、遍历数组 for…in const arr …

你好,我是沐爸,欢迎点赞、收藏、评论和关注。

在 JavaScript 中,for...infor...of 是两种用于遍历数组(或其他可迭代对象)的循环语句,但它们之间存在显著的差异。

一、遍历数组

for…in

const arr = ['apple', 'banana', 'cherry']for (const index in arr) {console.log(index, arr[index])
}
// 0 apple
// 1 banana
// 2 cherry

遍历数组的索引,访问数组元素通过 arr[index]形式。

for…of

const arr = ['apple', 'banana', 'cherry']for (const value of arr) {console.log(value)
}
// apple
// banana
// cherry

遍历数组元素,不能访问索引

二、遍历对象

for...in
const obj = {name: '张三',age: 20
}for (const key in obj) {console.log(key, obj[key])
}
// name 张三
// age 20

遍历对象的键(key),通过obj[key]访问属性的值。

for…of

const obj = {name: '张三',age: 20
}for (const key of obj) {console.log(key)
}
// TypeError: obj is not iterable

for...of 循环默认并不支持直接遍历对象的属性。因为for...of循环是为可迭代对象(如Array, Map, Set, arguments等)设计的,这些对象都有一个[Symbol.iterator]方法。

所以,常见的做法是结合 Object.keys()Object.values或者Object.entries() 进行遍历。

const obj = {name: '张三',age: 20
}for (const key of Object.keys(obj)) {console.log(key, obj[key])
}
// name 张三
// age 20for (const value of Object.values(obj)) {console.log(value)
}
// 张三
// 20for (const [key, value] of Object.entries(obj)) {console.log(key, value)
}
// name 张三
// age 20

另外,for…in 和 for…of 在遍历对象原型上的属性也有区别,for…in 会遍历对象原型上的属性,for…of 不会。

function Person(name, age) {this.name = namethis.age = age
}Person.prototype.say = function() {console.log('My Name is ' + this.name)
}const obj = new Person('张三', 20)for (const key in obj) {console.log(key, obj[key])
}
// name 张三
// age 20
// say [Function (anonymous)]for (const key of Object.keys(obj)) {console.log(key, obj[key])
}
// name 张三
// age 20

说准确点,并不是 for…of 不会遍历对象原型上的属性,而是 for…of 借助的 Object.keys()Object.valuesObject.entries()方法返回的数组只包含对象自身的属性和值。

如果想让 for…in 跟 for…of 一样只遍历对象自身的属性,可使用 hasOwnProperty

for (const key in obj) {if (obj.hasOwnProperty(key)) {console.log(key, obj[key])}
}

三、遍历其他类型数据

1.字符串
let str = "hello"for (const index in str) {console.log(index, str[index])
}
// 0 h
// 1 e
// 2 l
// 3 l
// 4 ofor (const value of str) {console.log(value)
}
// h
// e
// l
// l
// o

2.Set 结构

const set = new Set(['apple', 'banana', 'cherry'])for (const value in set) {console.log(value) // 这里几乎不会执行任何有用的操作,因为set没有可枚举的属性
}for (const value of set) {console.log(value)
}
// 输出(顺序可能不同,因为Set是无序的):
// apple
// banana
// cherry

3.Map结构

const map = new Map([['a', 1], ['b', 2], ['c', 3]])for (const value in map) {console.log(value) // 这里几乎不会执行任何有用的操作,因为map没有可枚举的属性
}for (const [key, value] of map) {console.log(key, value) 
}
// 输出:  
// a 1  
// b 2  
// c 3

4.类数组arguments

function fn(a, b, c) {for (const index in arguments) {console.log(index, arguments[index])}// 0 zhangsan// 1 20// 2 男for (const value of arguments) {console.log(value)}// zhangsan// 20// 男
}fn('zhangsan', 20, '男')

四、总结

通过以上示例可知,两者主要有以下区别:

  • for...in
    • 遍历对象的可枚举属性(包括原型链上的)
    • 对于数组,遍历的是索引(字符串类型)。
    • 不可遍历 Set 和 Map 结构
  • for...of
    • 遍历可迭代对象的值,直接访问值而不是键名或索引。
    • 不可直接变量对象,需要借助 Object.keys/values/entries。
    • 另外可遍历 Set 和 Map 结构

好了,分享结束,谢谢点赞,下期再见。

http://www.tj-hxxt.cn/news/114865.html

相关文章:

  • 寻找专业网站建设关键词优化推广
  • 网站彩铃怎么做的2023今天的新闻联播
  • 佛山市网站建设手机网站模板
  • 用ps怎么做网站首页北京最新消息今天
  • 自己如何做电影网站游戏推广公司怎么接游戏的
  • 容桂网站建设原创在百度怎么创建自己的网站
  • 做web网站时要添加图片大小网站软件下载大全
  • 信息技术网站建设专业樱桃bt官网
  • 官方网站建设要点搜索引擎优化排名培训
  • 山东网站优化公司我要学电脑哪里有短期培训班
  • wordpress好看的页面布局深圳seo排名优化
  • 如何做家乡网站除了百度指数还有哪些指数
  • 做网站需要去哪里备案软文的概念是什么
  • 广州高端品牌网站建设哪家公司好中文域名查询官网
  • 网站开发英文广西seo关键词怎么优化
  • 网站优化 保定网站怎么制作
  • 用vs2013网站开发新站整站优化
  • wordpress洛米主题关键词推广优化排名品牌
  • 网站建设所属行业新app推广去哪里找
  • 手机营销型网站制作谷歌seo优化
  • 武汉网站建设公司有哪些2345网址导航官方网站
  • vue 做企业网站行不谷歌seo怎么做
  • 鹤壁做网站的网络公司凡科建站小程序
  • 网站建设周期关键词排名优化公司推荐
  • asp.net 网站的头部和底部怎么来做 includeseo网站关键词优化费用
  • 百度做网站投广告免费seo网站自动推广软件
  • 南通网站外包微信推广怎么做
  • 莱芜新闻头条长尾词优化外包
  • 慈溪网站设计百度软件市场
  • 学做网站有多难百度seo什么意思