vue for of 跟 for in的用法

本文深入解析了for...of与for...in在遍历对象和数组时的不同表现。for...of适用于数组,能直接获取元素值;而for...in更适合遍历对象,返回的是对象的属性名。通过示例代码,清晰展示了两种循环结构的特点及适用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

vue for of 跟 for in的用法

对于普通的对象,for…of结构不能直接使用,会报错,必须部署了 Iterator 接口后才能使用,for-of用于数组对象。
但是,这样情况下,for…in循环依然可以用来遍历键名。

  let obj = {
    sex: '男',
    age: "39",
    name: "kexiaokang"
  };
  for (let e in obj) {
    console.log(e);
  }
  // sex
  // age
  // name
for of 遍历对象报错
  let obj = {
    sex: '男',
    age: "39",
    name: "kexiaokang"
  };
  for (let e of obj) {
    console.log(e);
  }
 demo.html:59 Uncaught TypeError: obj is not iterable

解决:
   for (let e of Object.keys(obj)) {
      console.log(e);
  }
Object.keys的使用其实相当于处理对象,返回可枚举的属性数组

两者遍历数组时:

  let es7 = [1, 2, 3, 4, 5, 6, 7]for (let e of es7) {
      console.log(e);
    }
	//1,2,3,4,5,6,7
	for (let e in es7) {
      console.log(e);
  	}
  	//0,1,2,3,4,5,6
  	//只能拿到索引

总结:for in 实用于遍历对象,for of 更适用于数组

v-forVue.js中的一个指令,它用于在模板中遍历数组或对象,并按照指定的方式进行渲染。可以通过在元素上使用v-for指令来循环渲染元素。在Vue.js中使用v-for指令需要结合in或者of来使用。 例如,在Vue.js中使用v-for指令来遍历数组,可以使用以下语法: ``` <ul> <li v-for="item in language">{{ item }}</li> </ul> ``` 其中,language就是要遍历的数组,item表示数组中的每个元素。在这个例子中,会根据language数组的长度复制相应数量的li元素,每个li元素中的内容为数组中的每个元素。 除了遍历数组,v-for指令也可以用于遍历对象。例如: ``` <ul> <li v-for="(item, index) in person">{{ index }}. 我会使用: {{ item }}</li> </ul> ``` 在这个例子中,person表示要遍历的对象,item表示对象中的每个属性值,index表示属性的索引。在每个li元素中,会显示索引值以及属性值。 总结来说,v-for指令是Vue.js中一个常用的遍历方法,它可以用于循环渲染数组或对象,并按照指定的方式进行渲染。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue快速入门(九) 之 v-for用法](https://blog.csdn.net/weixin_44415928/article/details/104904997)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue中v-for用法](https://blog.csdn.net/yilanyoumeng3/article/details/88176124)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值