【辰兮要努力】:hello你好我是辰兮,很高兴你能来阅读,昵称是希望自己能不断精进,向着优秀程序员前行!
博客来源于项目以及编程中遇到的问题总结,偶尔会有读书分享,我会陆续更新Java前端、后台、数据库、项目案例等相关知识点总结,感谢你的阅读和关注,希望我的博客能帮助到更多的人,分享获取新知,大家一起进步!
吾等采石之人,应怀大教堂之心,愿你们奔赴在各自的热爱中…
前端经常会遇到遍历一个list集合后,还要遍历其中每一个对象的某一个特定的属性,再循环显示,分享简单用法给初学者,希望对你有帮助!
业务场景:
1、我查询到一个人物list集合,每个人物会照片photos属性中会带几张照片,数量不等
2、查询房间的时候,带上房间的照片,除了遍历每个查询到的房间基础信息外还要遍历出每个房间的照片
items: [
id: 1,
name: "辰兮",
photos: [
{ img: "1.jpg" },
{ img: "2.jpg" },
{ img: "3.jpg" },
id: 2,
name: "chenxi",
photos: [
{ img: "4.jpg" },
{ img: "5.jpg" }
原理是一样的就是先遍历大的集合,再遍历每一个对象
<!-- 注意: v-for 循环的时候,key 属性只能使用 number获取string -->
<!-- 注意: key 在使用的时候,必须使用 v-bind 属性绑定的形式,指定 key 的值 -->
<!-- 在组件中,使用v-for循环的时候,或者在一些特殊情况中,
如果 v-for 有问题,必须 在使用 v-for 的同时,指定 唯一的 字符串/数字 类型 :key 值 -->
<div v-for="(item, key) in items" :key="key">
<p>{{item.name}}</p>
<div v-for="(photo,index) in item.photos" :key="index">
<span>{{photo.img}}</span>
</div>
补充:vue遍历中的key讲解
<!-- 注意: key 在使用的时候,必须使用 v-bind 属性绑定的形式,指定 key 的值 -->
<!-- key使用案例如下 -->
<li v-for="item in items" :key="item.id">...</li>
</ul>
key 的特殊属性主要用在 Vue 的虚拟 DOM 算法,在新旧 nodes 对比时辨识 VNodes。如果不使用 key,Vue 会使用一种最大限度减少动态元素并且尽可能的尝试修复/再利用相同类型元素的算法。使用 key,它会基于 key 的变化重新排列元素顺序,并且会移除 key 不存在的元素。
总结:key值的存在保证了唯一性,可以用于dom的重新渲染或是就地复用。
非常感谢你阅读到这里,如果这篇文章对你有帮助,希望能留下你的点赞👍 关注❤️ 分享👥 留言💬thanks!!!
愿你们奔赴在自己的热爱里!