v-for的用法及案例

欢迎来到我的UniApp技术专栏!🎉 在这里,我将与大家分享关于UniApp开发的实用技巧、最佳实践和项目经验。

专栏特色:

📱 跨平台开发一站式解决方案

🚀 从入门到精通的完整学习路径

💡 实战项目经验分享

🔍 常见问题深度解析

无论你是刚接触UniApp的新手,还是有一定经验的开发者,都能在这里找到有价值的内容。我将持续更新最新技术动态和开发技巧,帮助大家提升开发效率,打造高质量的跨平台应用。

如果文章对你有帮助,别忘了点赞收藏🌟,也欢迎在评论区留言交流,我会及时回复大家的问题!

让我们一起探索UniApp的无限可能!

目录

一.v-for的用法

1.举例1

2.举例2

二.购物车案例

1.代码

2.存在的问题:复选框错位

[3.解决方案: 赋值给key属性一个唯一的值](#3.解决方案: 赋值给key属性一个唯一的值)


一.v-for的用法

1.举例1

html 复制代码
<template>
	<view>
		<view v-for="(item,index) in 10" :key="index">box模块-{{ index+1 }}</view>
	</view>
</template>
 
<script setup>


</script>
 
<style lang="scss" scoped>
</style>

:key是生成的每一个view的唯一标志。

运行效果:

2.举例2

html 复制代码
<template>
	<view>
		<view v-for="item in nba" :key="item.id">
			球星:{{item.name}} - 球衣:{{item.num}}
		</view>
	</view>
</template>
 
<script setup>
import {ref} from 'vue';
const nba = ref([
	{id:1, name:"乔丹",num:23},
	{id:2, name:"詹姆斯",num:6},
	{id:3, name:"科比",num:24},
])

</script>
 
<style lang="scss" scoped>
</style>

运行效果:

二.购物车案例

1.代码

html 复制代码
<template>
	<view class="out">
		<view class="item" v-for="(item,index) in goods">
			<checkbox></checkbox>
			<text class="title">{{item.name}}</text>
			<text class="del" @click="remove(index)">删除</text>
		</view>
	</view>
</template>
 
<script setup>
import {ref} from 'vue';
//定义商品对象数组
const goods = ref([
	{id:11, name:"小米"},
	{id:22, name:"华为"},
	{id:33, name:"oppo"},
	{id:44, name:"苹果"},
])
//点击【删除】按钮,触发的事件
const remove = (index)=>{
	goods.value.splice(index, 1);//删除下标为index的元素
}
</script>
 
<style lang="scss" scoped>
.out{
	padding:10px;
	.item{
		padding:10px 0;
		.del{
			color:red;
			margin-left: 30px;
		}
	}
}
</style>

运行效果:

2.存在的问题:复选框错位

当我们选中某一个商品的复选框后,如果自己/上面的商品被删除了,复选框会发生错位,如下图所示:

3.解决方案: 赋值给key属性一个唯一的值

此时是vue底层算法问题,要想解决该问题,就得给使用v-for渲染的每一个项的key属性赋一个唯一的值,如下:

运行效果:

以上就是本篇文章的全部内容,喜欢的话可以留个免费的关注呦~

相关推荐
全栈前端老曹4 小时前
【前端组件封装教程】第3节:Vue 3 Composition API 封装基础
前端·javascript·vue.js·vue3·组合式api·组件封装
Sheldon一蓑烟雨任平生2 天前
Vue3 任务管理器(Pinia 练习)
vue.js·vue3·pinia·任务管理器·pinia 练习
云外天ノ☼2 天前
待办事项全栈实现:Vue3 + Node.js (Koa) + MySQL深度整合,构建生产级任务管理系统的技术实践
前端·数据库·vue.js·mysql·vue3·koa·jwt认证
行走的陀螺仪3 天前
uni-app + Vue3 实现折叠文本(超出省略 + 展开收起)
前端·javascript·css·uni-app·vue3
星光一影3 天前
打车/网约车、代驾、顺风车/拼车、货运、租车等多种出行服务的一站式解决方案
mysql·微信小程序·php·uniapp·html5·web app
星光一影3 天前
悬赏任务平台/拉新地推系统源码
redis·mysql·小程序·php·uniapp·html5
小禾青青4 天前
uniapp开发ai对话app,使用百度语音识别用户输入内容并展示到页面上
人工智能·百度·uni-app·uniapp
Sheldon一蓑烟雨任平生5 天前
Vue 用户管理系统(路由相关练习)
vue.js·vue3·axios·json-server·vue-router·vue 路由·vue-link
Sheldon一蓑烟雨任平生5 天前
Vue3 插件(可选独立模块复用)
vue.js·vue3·插件·vue3 插件·可选独立模块·插件使用方式·插件中的依赖注入
IT教程资源C7 天前
(N_158)基于微信小程序学生社团管理系统
mysql·vue3·前后端分离·社团小程序·springboot社团小程序