react中v-for列表循环

前言:在vue中如果想要将数组中的数据进行循环的时候可以直接使用封装好的v-for指令进行实现,但是在react中是没有这种指令的,那么在react中是怎样实现列表的循环呢,下面一起看下react中是怎样实现的。

1、数组中的数据渲染

在平时开发中我们经常会遇到数组包含一系列数据的情况,然后在页面上展示出符合条件的数据,在react的jsx语法中我们可以直接将数组循环并将需要渲染的元素返回即可,如:

import React from 'react'
const listData = [
  {
    id: 1,
    text: '我是第一条数据'
  },
  {
    id: 2,
    text: '我是第二条数据'
  },
  {
    id: 3,
    text: '我是第三条数据'
  }
]
export default function ForRender() {
  return (
    <div>
      <ul>
        {
          listData.map(item => {
            if (item.id === 2) return 
            return <li key={item.id}>{item.text}</li>
          })
        }
      </ul>
    </div>
  )
}

在上述代码中,在jsx语法中使用了数组中的map方法对listData进行循环映射,每一项返回使用合适的元素标签进行包裹的内容,在循环的过程中过滤掉不符合条件的id为2的那条数据来进行展示。(注意循环的时候为了diff算法的对比记得给元素添加key属性)。效果如下:
在这里插入图片描述

2、对象中的数据渲染

上面我们演示了数据中的数据循环渲染,但是有的时候还有一些是对象的数据也要渲染,那么我们直接使用将对象转换为数组的方法然后在进行循环即可,如:

import React from 'react'
const objData = {
  1: '我是第一条数据',
  2: '我是第二条数据',
  3: '我是第三条数据',
}
export default function ForRender() {
  return (
    <div>
      <ul>
        {
          Object.entries(objData).map(([id, text]) => {
            return <li key={id}>{id + '、' + text}</li>
          })
        }
      </ul>
    </div>
  )
}

上述代码使用了entries方法将对象转换为了数组,然后在使用map方法根据数组展示的方法那样循环展示出来即可。效果如下:
在这里插入图片描述

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在Vue,router-link和v-for是两个不同的指令,用于不同的场景。 router-link是Vue Router提供的指令,用于生成一个链接,用于导航到不同的路由。它可以通过to属性指定目标路由的路径,也可以通过tag属性指定生成的标签类型。router-link可以根据路由的变化自动添加或移除active类,以便在当前路由匹配时应用样式。\[1\] v-for是Vue的一个指令,用于循环渲染列表数据。它可以通过指定一个数组或对象来遍历数据,并使用特定的模板来渲染每个项。v-for可以使用item in items的语法来指定循环的方式,也可以使用item,index in items的语法来获取索引。\[2\] 因此,router-link和v-for是用于不同的场景。router-link用于生成导航链接,而v-for用于循环渲染列表数据。 #### 引用[.reference_title] - *1* *3* [vue路由router切换](https://blog.csdn.net/spring_world_all/article/details/86500599)[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^v91^control_2,239^v4^insert_chatgpt"}} ] [.reference_item] - *2* [react-router-dom 简明教程](https://blog.csdn.net/IT_bar/article/details/117002395)[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^v91^control_2,239^v4^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值