vue2技能树(5)-条件渲染和列表渲染
目录
- Vue 2 条件渲染详解
- `v-if` 和 `v-else` 指令
- 项目示例
- `v-show` 指令
- 项目示例
- `v-if` 和 `v-show` 的区别
- `v-if` 和 `v-else-if` 指令
- 项目示例
- Vue 2 列表渲染详解
- `v-for` 指令
- 项目示例
- 计算属性和方法
- 项目示例
- `v-bind:key`
- 项目示例
- 使用对象的`v-for`
- 项目示例
- `v-for` 的索引
- 项目示例
👍 点赞,你的认可是我创作的动力!
⭐️ 收藏,你的青睐是我努力的方向!
✏️ 评论,你的意见是我进步的财富!
Vue 2 条件渲染详解
条件渲染是Vue.js 2中一个重要的概念,它允许你根据特定的条件来决定是否渲染或显示某个DOM元素。这是构建动态和交互性用户界面的关键部分。以下是对Vue 2条件渲染的多方面详细介绍,包括使用详细的项目实例。
v-if
和 v-else
指令
v-if
和 v-else
指令是用于条件渲染的核心指令。它们允许你根据给定的条件来显示或隐藏元素。
项目示例
假设你有一个简单的任务清单应用,你希望根据是否存在任务来显示不同的提示信息。你可以使用v-if
和 v-else
来实现这一目标。
<div id="app"><h1>任务清单</h1><div v-if="tasks.length > 0"><h2>任务列表:</h2><ul><li v-for="task in tasks">{{ task }}</li></ul></div><div v-else><p>暂无任务。</p></div>
</div>
new Vue({el: '#app',data: {tasks: ['任务1', '任务2', '任务3'],},
});
在这个示例中,根据tasks
数组是否为空,你可以决定是否渲染任务列表或者显示“暂无任务”的提示。
v-show
指令
v-show
指令类似于v-if
,但它不是真正的条件渲染,而是使用CSS的display
属性来隐藏或显示元素。如果你需要频繁切换元素的可见性,v-show
可能更适合。
项目示例
继续上面的任务清单应用示例,你可以使用v-show
来切换任务列表的可见性。
<div v-show="tasks.length > 0"><h2>任务列表:</h2><ul><li v-for="task in tasks">{{ task }}</li></ul>
</div>
在这个示例中,当tasks
数组不为空时,任务列表会显示;当tasks
数组为空时,任务列表会被隐藏,但DOM元素仍然存在。
v-if
和 v-show
的区别
v-if
:在条件为假时,元素不会存在于DOM中,因此它对性能有较好的优化。但频繁切换时可能会有一些性能开销。v-show
:元素始终存在于DOM中,只是使用CSS的display
属性来控制可见性。这在频繁切换时可能更快,但可能会有轻微的性能开销。
你可以根据你的需求和性能优化考虑选择使用v-if
还是v-show
。
v-if
和 v-else-if
指令
除了v-if
和 v-else
,Vue 2还提供了v-else-if
用于多条件渲染。这在你有多个条件要满足时非常有用。
项目示例
假设你的任务清单应用有三个状态:进行中、已完成和已取消。你可以使用v-else-if
来渲染不同状态的任务。
<div v-if="status === 'inProgress'"><h2>进行中的任务:</h2><ul><li v-for="task in inProgressTasks">{{ task }}</li></ul>
</div>
<div v-else-if="status === 'completed'"><h2>已完成的任务:</h2><ul><li v-for="task in completedTasks">{{ task }}</li></ul>
</div>
<div v-else><h2>已取消的任务:</h2><ul><li v-for="task in canceledTasks">{{ task }}</li></ul>
</div>
在这个示例中,根据status
的值,你可以决定渲染不同状态的任务列表。
条件渲染是Vue 2的强大功能,它使你可以根据数据的变化来控制元素的显示和隐藏,以实现动态和交互性的用户界面。
Vue 2 列表渲染详解
列表渲染是Vue.js 2中一个强大的功能,它允许你轻松地渲染数据列表到DOM中。Vue提供了多种指令和方法来实现列表渲染,包括v-for
指令、计算属性和方法。以下是对Vue 2列表渲染的多方面详细介绍,包括使用详细的项目实例。
v-for
指令
v-for
指令是Vue中用于循环渲染元素的核心指令。它允许你在模板中基于数据数组或对象的每个项来重复渲染元素。
项目示例
假设你有一个任务清单应用,你可以使用v-for
来渲染任务列表。
<div id="app"><h1>任务清单</h1><ul><li v-for="task in tasks">{{ task }}</li></ul>
</div>
new Vue({el: '#app',data: {tasks: ['任务1', '任务2', '任务3'],},
});
在这个示例中,v-for
指令循环遍历tasks
数组中的每个任务,并将它们渲染成列表项。
计算属性和方法
除了v-for
,你还可以使用计算属性和方法来进行列表渲染。这对于复杂的列表操作非常有用。
项目示例
假设你有一个包含任务的数组,并希望渲染已完成的任务的数量。
<div id="app"><h1>任务清单</h1><ul><li v-for="task in completedTasks">{{ task }}</li></ul><p>已完成任务数:{{ completedTaskCount }}</p>
</div>
new Vue({el: '#app',data: {tasks: [{ text: '任务1', completed: true },{ text: '任务2', completed: false },{ text: '任务3', completed: true },],},computed: {completedTasks: function() {return this.tasks.filter(task => task.completed);},completedTaskCount: function() {return this.completedTasks.length;},},
});
在这个示例中,completedTasks
计算属性用于过滤已完成的任务,并将它们渲染成列表项。completedTaskCount
计算属性用于计算已完成任务的数量。
v-bind:key
在使用v-for
进行列表渲染时,你应该为每个渲染的元素提供一个唯一的key
属性。这有助于Vue更有效地管理DOM元素。
项目示例
<div id="app"><ul><li v-for="task in tasks" v-bind:key="task.id">{{ task.text }}</li></ul>
</div>
在这个示例中,v-bind:key
用于为每个任务列表项提供一个唯一的标识,通常使用任务的ID。
使用对象的v-for
除了数组,你还可以使用对象进行v-for
进行列表渲染。
项目示例
假设你有一个包含任务的对象,每个任务都有一个唯一的键。
<div id="app"><ul><li v-for="(task, key) in tasks" v-bind:key="key">{{ task }}</li></ul>
</div>
new Vue({el: '#app',data: {tasks: {task1: '任务1',task2: '任务2',task3: '任务3',},},
});
在这个示例中,v-for
用于遍历任务对象,key
作为任务的唯一标识。
v-for
的索引
除了元素值,v-for
还可以提供索引值。
项目示例
<div id="app"><ul><li v-for="(task, index) in tasks" v-bind:key="index">{{ task }}</li></ul>
</div>
在这个示例中,index
是任务在数组中的索引值。
列表渲染是Vue 2的一个强大特性,它使你可以轻松地渲染数据列表,无论是使用v-for
指令、计算属性还是方法,都提供了多种方式来满足不同的需求。这使得Vue成为一个出色的前端框架,用于构建动态和交互性的用户界面。
相关文章:
vue2技能树(5)-条件渲染和列表渲染
目录 Vue 2 条件渲染详解v-if 和 v-else 指令项目示例 v-show 指令项目示例 v-if 和 v-show 的区别v-if 和 v-else-if 指令项目示例 Vue 2 列表渲染详解v-for 指令项目示例 计算属性和方法项目示例 v-bind:key项目示例 使用对象的v-for项目示例 v-for 的索引项目示例 …...
MySQL基本操作之创建数据库
1、大小写敏感 一般大家都默认使用:小写 在MySQL中,大小写敏感性有两个方面的规定:lower_case_file_system和lower_case_table_names。 lower_case_file_system:指定操作系统文件系统是否对大小写敏感。 当设置为ON时,表示文件系统对大小写不敏感;当设置为OFF时,表示…...

8.对象贴地
愿你出走半生,归来仍是少年! 在场景中,有时候需要对地物(房屋、楼宇)进行贴地处理,或者说相对地面高度(井盖、井室)进行设置。 通过自定义的Terrain切片以及影像瓦片构建的三维场景应该如何获取…...

AWS Lambda – 函数版本,别名,API网关,CodeDeploy协同
Hello大家好,我们今天继续讨论AWS Lambda的内容。 Lambda函数的版本 Lambda函数的版本和别名是辅助资源,我们可以通过创建这些资源管理函数的部署和调用。 首先,让我们来看一下Lambda 函数版本的概念。您可以使用版本来管理函数的部署。例…...

flutter doctor检测环境,出现CocoaPods installed but not working
1. 安装flutter, 地址: 安装和环境配置 - Flutter 中文文档 - Flutter 中文开发者网站 - Flutter 2. 安装成功后,通过flutter doctor检测环境。以mac为例,出现了CocoaPods installed but not working 错误提示时,以下为解决方案: 2.1 rvm i…...
Python 条件和 if 语句
Python支持来自数学的通常逻辑条件: 等于:a b不等于:a ! b小于:a < b小于或等于:a < b大于:a > b大于或等于:a > b 这些条件可以以多种方式使用,最常见的是在"i…...

行业领先的三个企业正在利用聊天机器人变得更强
聊天机器人已成为客户服务领域的革命者,深刻地改变了企业与客户互动的方式。这些虚拟助手简化了交互,提供了24/7全天候高效和个性化的支持。凭借先进的技术和自然语言处理能力,聊天机器人擅长快速处理查询。 效率是聊天机器人的关键优势。它…...
「Git|场景案例」从项目中删除之前commit过的文件并且让git不追踪删除操作
本文主要介绍如何在git中删除文件但是让git不追踪这些删除操作 文章目录 场景说明解决方案删除一个文件删除一个文件夹以及子文件夹 场景说明 自己在使用react开发一个包含大量媒体文件的网站时,项目初期临时将这些媒体文件都放在项目中,直接使用访问本…...

一款.NET Core开源的基于Vue+ElementUI开发的博客系统 - StarBlog
前言 今天给大家推荐一款.NET Core开源的基于VueElementUI开发的博客系统 - StarBlog。该项目配套详细的文章教程,可以作为 .Net Core 入门项目学习。 官方项目介绍 StarBlog支持Markdown导入的博客。后端基于最新的.Net6和Asp.Net Core框架,遵循REST…...

用git stash暂存修改
git stash命令用于保存当前工作目录的临时状态,包括暂存区和已修改但未暂存的文件。它会将这些修改保存在一个临时区域(即“堆栈”)中,让你能够回到一个干净的工作目录,可以进行其他操作。等到你完成其他任务后&#x…...

一个适合练手的接口测试实战项目——慕慕生鲜
前言 最近很多粉丝找小月要接口测试项目练练手,看看实力!今天,它来了 慕慕生鲜,完整版,文末有福利! 干货来咯,收藏好! 1. 接口测试需求分析 常见接口文档提供的两种方式 ①wor…...

window10/11 光学系统建模之Light Tools8.6 软件安装教程(亲测可用+附带免费资源可直接下载)
1.下载链接 (免费分享) 链接:https://pan.baidu.com/s/1qVubyRSC93xT-GKeK-k3ow 提取码:vkho 2.安装顺序 即按照图里的1234的顺序先安装完注册表,驱动,和lighttools的程序 我个人在win10系统安装这些程…...

Vue3+ElementPlus el-date-picker时间选择器,设置最多选择60天区间内,必须选择大于今天
Vue3ElementPlus el-date-picker时间选择设置, 必须选择大于今天;最多选择60天区间内; 使用disabled-date: 具体实现代码: <el-date-pickerv-model"state.queryParams.dateTime":editable"false&q…...

2022年亚太杯APMCM数学建模大赛B题高速列车的优化设计求解全过程文档及程序
2022年亚太杯APMCM数学建模大赛 B题 高速列车的优化设计 原题再现: 2022年4月12日,中国高铁复兴号CR450动车组在开放线上成功实现单车时速435公里,相对速度870公里,创造了高铁动车组列车穿越开放线和隧道速度的世界纪录。新一代…...

OSI网络分层模型
OSI英文全文是Open System Interconnection Reference Model,翻译成中文就是开放式系统互联通信参考模型。 OSI模型分成了七层,部分层次与 TCP/IP 很像,从下到上分别是: 第一层:物理层,网络的物理形式&…...
EOS区块链keosd的RPC API
list_wallets 查看钱包列表 post v1/wallet/list_walletsapi: http://127.0.0.1:8888/v1/wallet/list_walletsparams: 无returns: ["testnet *" ]testnet:钱包名称create 创建钱包 post v1/wallet/createapi: http://127.0.0.1:8888/v1/wallet/createpa…...

React +AntD + From组件重复提交数据(已解决)
开发场景: react Hooks andt 提交form表单内容给数据库(使用antd的form组件) 问题描述 提交是异步的,请提交方式是POST 方式 提交表单内容给后端,却产生了两次提交记录(当然,数据新增了两条数据)。可以…...
spring的简单使用(配合Druid操作数据库)
文章目录 准备数据pom.xml文件中引用需要的库准备好dao层接口和service层接口和实现类准备好 jdbc.properties 和 user.properties编写Druid的jdbcConfig配置类编写spring的配置类SpringConfig编写Dao层的实现类的逻辑测试类参考文献 准备数据 create database if not exists …...
10.20作业
#include “widget.h” #include “ui_widget.h” Widget::Widget(QWidget *parent) QWidget(parent) , ui(new Ui::Widget) { ui->setupUi(this); t new QTimer(this); connect(t, &QTimer::timeout, this, &Widget::timeout_Slot); ui->text->setPlacehold…...
笔记1 Compute Shaders
Wending 2022/10/29 15:43:54 Compute Shaders是在GPU运行却又在普通渲染管线之外的程序,通过Compute Shader我们可以将大量可以并行的计算放到GPU中计算从而节省CPU资源 Wending 2022/10/29 15:44:27 反正不是传统的shader 不常用 博毅创为Blake老师 2022/10/29 15…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...
设计模式和设计原则回顾
设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...

超短脉冲激光自聚焦效应
前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应,这是一种非线性光学现象,主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场,对材料产生非线性响应,可能…...
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以? 在 Golang 的面试中,map 类型的使用是一个常见的考点,其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...
线程与协程
1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指:像函数调用/返回一样轻量地完成任务切换。 举例说明: 当你在程序中写一个函数调用: funcA() 然后 funcA 执行完后返回&…...
java调用dll出现unsatisfiedLinkError以及JNA和JNI的区别
UnsatisfiedLinkError 在对接硬件设备中,我们会遇到使用 java 调用 dll文件 的情况,此时大概率出现UnsatisfiedLinkError链接错误,原因可能有如下几种 类名错误包名错误方法名参数错误使用 JNI 协议调用,结果 dll 未实现 JNI 协…...

华为OD机试-食堂供餐-二分法
import java.util.Arrays; import java.util.Scanner;public class DemoTest3 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint a in.nextIn…...

跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...

【2025年】解决Burpsuite抓不到https包的问题
环境:windows11 burpsuite:2025.5 在抓取https网站时,burpsuite抓取不到https数据包,只显示: 解决该问题只需如下三个步骤: 1、浏览器中访问 http://burp 2、下载 CA certificate 证书 3、在设置--隐私与安全--…...

HBuilderX安装(uni-app和小程序开发)
下载HBuilderX 访问官方网站:https://www.dcloud.io/hbuilderx.html 根据您的操作系统选择合适版本: Windows版(推荐下载标准版) Windows系统安装步骤 运行安装程序: 双击下载的.exe安装文件 如果出现安全提示&…...