【辰兮要努力】: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">
          <div>
            <div>
              <p>{{item.name}}</p>
            </div>
              <div v-for="(photo,index) in item.photos" :key="index">
                <span>{{photo.img}}</span>    
              </div>
          
          </div>
        </div>

补充:vue遍历中的key讲解

    <!-- 注意: key 在使用的时候,必须使用 v-bind 属性绑定的形式,指定 key 的值 -->
    <!-- key使用案例如下 -->
<ul>
  <li v-for="item in items" :key="item.id">...</li>
</ul>

key 的特殊属性主要用在 Vue 的虚拟 DOM 算法,在新旧 nodes 对比时辨识 VNodes。如果不使用 key,Vue 会使用一种最大限度减少动态元素并且尽可能的尝试修复/再利用相同类型元素的算法。使用 key,它会基于 key 的变化重新排列元素顺序,并且会移除 key 不存在的元素。

总结:key值的存在保证了唯一性,可以用于dom的重新渲染或是就地复用。


非常感谢你阅读到这里,如果这篇文章对你有帮助,希望能留下你的点赞👍 关注❤️ 分享👥 留言💬thanks!!!

2021年1月30日22:00:56 愿你们奔赴在自己的热爱里!

Logo

前往低代码交流专区

更多推荐