vue遍历数组对象中的数组集合(Demo案例)

简介: 前端经常会遇到遍历一个list集合后,还要遍历其中每一个对象的某一个特定的属性,再循环显示,分享简单用法给初学者,希望对你有帮助!
【辰兮要努力】: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!!!

愿你们奔赴在自己的热爱里!

目录
相关文章
|
1月前
|
资源调度 JavaScript API
解锁一个尚未被 Vue 正式实现的提案或想法集合的库,真的很有趣!
解锁一个尚未被 Vue 正式实现的提案或想法集合的库,真的很有趣!
|
1月前
|
JavaScript 数据处理
如何使用 Vue.js 将数据对象的值放入另一个数据对象中?
如何使用 Vue.js 将数据对象的值放入另一个数据对象中?
|
1月前
|
JavaScript 前端开发 开发者
Vue.js 2 项目实战(四):成绩案例
Vue.js 2 项目实战(四):成绩案例
|
1月前
|
JavaScript 前端开发 开发者
Vue.js 2 项目实战(三):综合案例-小黑记事本
Vue.js 2 项目实战(三):综合案例-小黑记事本
|
1月前
|
JavaScript 前端开发 开发者
Vue.js 2 项目实战(二):图书管理案例
Vue.js 2 项目实战(二):图书管理案例
|
1月前
|
JavaScript 前端开发 开发者
Vue.js 2 项目实战(一):图片切换案例
Vue.js 2 项目实战(一):图片切换案例
|
2月前
|
JavaScript
Base64如何切割后面的内容,如何提取data:image/png;base64,之后的内容,Vue中.split中截取的数组如何使用数组进行获取
Base64如何切割后面的内容,如何提取data:image/png;base64,之后的内容,Vue中.split中截取的数组如何使用数组进行获取
|
2月前
|
JavaScript
Vue插值表达式数组写法,插值表达式,如何插入数据,数组,集合,{{}}多项数据显示页面的写法
Vue插值表达式数组写法,插值表达式,如何插入数据,数组,集合,{{}}多项数据显示页面的写法
|
2月前
|
JavaScript
vue 渲染树型数据(含树型数据转化为一维数组的方法,包括每个节点的深度和深度列表)
vue 渲染树型数据(含树型数据转化为一维数组的方法,包括每个节点的深度和深度列表)
32 0
|
2天前
|
JavaScript
vue中watch的用法
vue中watch的用法