VUE3.0-列表渲染

我们可以使用 v-for 指令基于一个数组来渲染一个列表。v-for 指令的值需要使用 item in items 形式的特殊语法,

其中 items 是源数据的数组,而 item 是迭代项的别名

javascript 复制代码
<template>
  <h3>列表渲染</h3>
<p v-for="item in names">{{ item }}</p>
</template>

<script>
export default {
    data() {
        return{
            names:[
                '李德华','张学友','周杰伦','林俊杰'
            ]
        }
    }
} 

</script>

复杂数据

大多数情况,我们渲染的数据源来源于网络请求,也就是 JSON 格式

javascript 复制代码
<template>
  <h3>列表渲染</h3>
    <div v-for="item in result">
    <p>{{ item.title }}</p>
    <img :src="item.avator" alt="">
</div>
</template>

<script>
export default {
    data() {
        return{
            result:[
                {
                    "id":2261677,
                    "title": "鄂尔多斯|感受一座城市的璀璨夜景 感受一座城市,除了白日里的车水马龙,喧器繁华之",
                    "avator":"https://pic.qyer.com/avatar/002/25/77/30/200?V=1560226451",
                },
                {
                    "id":2261566,
                    "title": "成都这家洞穴暗黑风咖啡厅酷毙了!早c晚A走起>成都天气这么热。咖啡*人必",
                    "avator": "https://pic.ever.com/avatar/e11/87/89/69/zcerx-4537218313e",
                },
                {
                    "id":2261662,
                    "title":"川西新龙-措卡湖】措卡湖,意为"乱石从中的黑色海水",神秘小众 原汁原味。深",
                    "avator":"https://pic.qyer.com/avatar/009/88/48/58/200?V=1507386782",
                },
                ]
    }
} 
}
</script>

v-for 也支持使用可选的第二个参数表示当前项的位置索引

javascript 复制代码
<template>
  <h3>列表渲染</h3>
<p v-for="(name, index) in names">{{ name }}-{{ index }}</p>

</template>

<script>
export default {
    data() {
        return{
            names:['李德华','张学友','周杰伦','林俊杰'],

</script>

你也可以使用of作为分隔符来替代in,这更接近 JavaScript 的迭代器语法

javascript 复制代码
<p v-for="(name, index) of names">{{ name }}-{{ index }}</p>

v-for与对象

你也可以使用 v-for 来遍历一个对象的所有属性

javascript 复制代码
<template>
  <h3>列表渲染</h3>
    <p v-for="(value,key,index) in userInfo">{{ value }}-{{ key }}-{{ index }}</p>
</div>
</template>

<script>
export default {
    data() {
        return{
                userInfo:{
                    name:'zhansgan',
                    age:25,
                    sex:'男',
                }
    }
} 
}
</script>
相关推荐
持久的棒棒君4 小时前
npm安装electron下载太慢,导致报错
前端·electron·npm
渔舟唱晚@5 小时前
大模型数据流处理实战:Vue+NDJSON的Markdown安全渲染架构
vue.js·大模型·数据流
crary,记忆6 小时前
Angular微前端架构:Module Federation + ngx-build-plus (Webpack)
前端·webpack·angular·angular.js
漂流瓶jz6 小时前
让数据"流动"起来!Node.js实现流式渲染/流式传输与背后的HTTP原理
前端·javascript·node.js
SamHou07 小时前
手把手 CSS 盒子模型——从零开始的奶奶级 Web 开发教程2
前端·css·web
我不吃饼干7 小时前
从 Vue3 源码中了解你所不知道的 never
前端·typescript
开航母的李大7 小时前
【中间件】Web服务、消息队列、缓存与微服务治理:Nginx、Kafka、Redis、Nacos 详解
前端·redis·nginx·缓存·微服务·kafka
Bruk.Liu7 小时前
《Minio 分片上传实现(基于Spring Boot)》
前端·spring boot·minio
鱼樱前端8 小时前
Vue3+d3-cloud+d3-scale+d3-scale-chromatic实现词云组件
前端·javascript·vue.js
q_19132846958 小时前
基于Springboot+Vue的办公管理系统
java·vue.js·spring boot·后端·intellij idea