0

0

Vue文档中的条件渲染函数实例分析

PHPz

PHPz

发布时间:2023-06-21 10:09:39

|

1539人浏览过

|

来源于php中文网

原创

vue是一款非常流行的javascript框架,它提供了一些方便开发者的工具和功能,让开发者可以更方便地构建复杂的web应用程序。其中,条件渲染函数是vue中一个非常有用的功能,可以帮助开发者动态地控制和渲染页面上的元素。在本文中,我们将对vue文档中的条件渲染函数进行分析和实例演示。

一、Vue的条件渲染函数简介

Vue中可以使用v-if和v-show指令来实现条件渲染。这些指令都可以让我们根据条件来控制某些元素是否需要渲染到页面上。

v-if指令是根据表达式的值来判断是否需要渲染元素,如果表达式的值为真,则渲染该元素;否则,不渲染该元素。例如:

这是一个需要被渲染出来的div元素

在上面的例子中,只有当Vue实例的shown属性值为true时,才会在页面上渲染出这个div元素。

立即学习前端免费学习笔记(深入)”;

v-show指令也可以实现元素的条件渲染,但是它的实现方式和v-if有点不同。v-show指令是根据表达式的值来动态改变元素的display属性,如果表达式的值为真,则将元素的display属性设置为block,从而让元素在页面上显示出来;否则,将元素的display属性设置为none,从而让元素在页面上被隐藏起来。例如:

这是一个需要被渲染出来的div元素

在上面的例子中,只要Vue实例的shown属性值为true,这个div元素就会显示出来,否则就会被隐藏起来。

二、v-if和v-show的差异点

虽然v-if和v-show都可以实现元素的条件渲染,但是它们在实现方式上有所区别,主要表现在以下几个方面:

  1. 渲染开销

v-if指令是在每次渲染时都会重新判断条件表达式的值,并且根据该表达式的值来添加或移除元素。因此,当条件表达式的值较为复杂或者元素较多时,v-if的渲染开销会比较大。

v-show指令只是通过动态改变元素的display属性来隐藏或显示元素,不需要重新创建或移除元素,因此渲染开销比较小。但是,在元素的初始渲染时,v-show指令需要先判断条件表达式的值,并根据该值来设置元素的display属性,因此渲染速度可能会比v-if慢一些。

  1. 初始化渲染开销

v-if指令在条件表达式初始为false的情况下,不会进行渲染。只有当条件表达式的值变为true时,才会开始进行渲染。因此,v-if的初始化渲染开销会比v-show小一些。

v-show指令在初始渲染时,会根据条件表达式的值来动态设置元素的display属性,从而决定元素是否显示。因此,v-show的初始化渲染开销会比v-if大一些。

  1. 渲染性能

v-if指令在条件表达式的值变化时,会重新进行判断,并重新创建或移除对应的元素。在只有少量元素需要动态渲染时,v-if的性能会比v-show略好一些。

v-show指令只是通过动态改变元素的display属性来控制元素的显示和隐藏,不需要重新创建或移除元素。因此,在需要频繁切换元素显示和隐藏的情况下,v-show的性能会比v-if好一些。

三、v-if和v-show使用场景的选择

基于上述不同点,我们可以根据实际需求来选择v-if和v-show。

当需要频繁切换元素的显示和隐藏时,可以选择使用v-show指令。例如:用于显示和隐藏某些操作面板或对话框、切换菜单等。

MiniMax Agent
MiniMax Agent

MiniMax平台推出的Agent智能体助手

下载

当需要根据复杂逻辑判断是否需要渲染某些元素,或者需要动态创建或移除元素时,可以选用v-if指令。例如:根据用户的登录状态来渲染页面中的某些元素、根据用户权限来渲染页面中的某些操作按钮等。

四、实例分析

下面我们来基于一个实例来演示v-if和v-show的使用。

假设我们需要在页面上展示一份商品列表。列表中分别包含商品的名称、价格、库存及购买按钮等信息。同时,该列表还需要提供一个筛选功能,使用户可以根据不同条件来查看不同的商品信息。具体实现如下:

  1. 定义商品列表数据

首先我们需要定义一个包含商品信息的数组,这里我们暂时假定数组中已经包含了10个商品的信息。该数组的格式如下:

goodsList: [
  {
    name: "商品A",
    price: 100,
    stock: 50
  },
  {
    name: "商品B",
    price: 200,
    stock: 80
  },
  ...
]
  1. 定义筛选条件和筛选结果数据

为了实现筛选功能,我们需要定义一个表单,该表单中包含了用于筛选的条件输入框。通过这些输入框,用户可以输入不同的筛选条件来查看不同的商品信息。

同时,我们还需要定义一个变量来存储筛选后的结果,从而将不符合筛选条件的商品过滤掉。 筛选条件和筛选结果的定义如下:

filterForm: {
  name: "",
  minPrice: "",
  maxPrice: ""
},
filteredGoodsList: []
  1. 实现筛选逻辑

为了实现筛选功能,我们需要在Vue实例中定义一个方法,该方法会在每次需要筛选时被调用。该方法会根据用户输入的筛选条件,从商品列表中筛选出符合条件的商品,并将结果存储到filteredGoodsList中。

具体实现代码如下:

methods: {
  filterGoodsList() {
    let filterName = this.filterForm.name.toLowerCase()
    let filterMinPrice = this.filterForm.minPrice ? parseInt(this.filterForm.minPrice) : Number.MIN_SAFE_INTEGER
    let filterMaxPrice = this.filterForm.maxPrice ? parseInt(this.filterForm.maxPrice) : Number.MAX_SAFE_INTEGER
    this.filteredGoodsList = this.goodsList.filter((item) => {
      let itemName = item.name.toLowerCase()
      return itemName.indexOf(filterName) !== -1 && item.price >= filterMinPrice && item.price <= filterMaxPrice
    })
  }
}

在这个方法中,我们首先将用户输入的筛选条件分别提取出来,并将maxPrice和minPrice转换为数字类型。然后,我们使用JavaScript数组的filter方法,从商品列表中筛选出符合条件的商品。可以看到,我们使用了itemName.indexOf(filterName) !== -1这种方式,即通过JavaScript中字符串的indexOf方法来检查itemName是否包含了filterName这个子串。如果包含,则返回true,表示该商品符合筛选条件;否则返回false,表示该商品不符合筛选条件。最后,我们将筛选结果存储到filteredGoodsList中。

  1. 实现列表渲染

我们可以通过v-for指令来遍历filteredGoodsList数组,并将每个数组元素渲染成一个商品信息块。具体实现代码如下:

{{ item.name }}
{{ item.price }}
{{ item.stock }}
购买
已售罄

在这个代码中,我们将v-for指令绑定到filteredGoodsList数组上,这样就可以遍历这个数组中的所有元素。我们使用: key="index"来为每个元素设置一个唯一的key值,以便Vue能够高效地对列表进行更新。

在每个商品信息块中,我们使用v-show和v-if指令来根据不同的商品库存信息来动态展示不同的元素。如果该商品库存大于0,则会显示购买按钮;否则,会显示“已售罄”的文字提示。

  1. 实现筛选表单和筛选按钮

最后,我们需要在页面上添加一个筛选表单,让用户可以输入不同的筛选条件来观察不同的商品信息。表单的代码如下:

-

在这个代码中,我们使用了v-model指令将表单元素和Vue实例中的filterForm对象绑定在一起,从而实现了双向数据绑定。我们还添加了一个筛选按钮,在用户点击按钮时会触发filterGoodsList方法,从而重新进行商品列表的筛选和渲染。

六、总结

通过以上分析和实例演示,我们了解了Vue文档中的条件渲染函数的基本知识和使用方法,以及v-if和v-show指令在渲染开销、初始化渲染开销和渲染性能等方面的不同表现。最后,我们还运用条件渲染函数的知识,实现了一个商品列表及其筛选功能的实例。相信这些内容能够对您学习和使用Vue框架提供一些帮助。

相关专题

更多
Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

37

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

37

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

交互式图表和动态图表教程汇总
交互式图表和动态图表教程汇总

本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

9

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 6.4万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号