你可能被 Vue 中的 v-show 骗了,它并没有像你想的那样切换 display 的属性

2024-09-02 19:20

本文主要是介绍你可能被 Vue 中的 v-show 骗了,它并没有像你想的那样切换 display 的属性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

你好同学,我是沐爸,欢迎点赞、收藏、评论和关注!

在 Vue 中 v-show 是如何条件性地渲染内容的,你可能知道是通过切换 display 属性实现,但真的跟你想的一样吗?

一、你被骗了吗?

v-showv-if 指令都是用于条件性地渲染一块内容,但表达式的值为真时,显示内容,为假时,隐藏内容。

对于两者的区别,你应该也了如指掌:v-if 是真正的条件渲染;v-show 始终会被渲染,只有 CSS display 属性会被切换。

不知道你是怎么理解 “只有 CSS display 属性会被切换” ?如果你是觉得将 display 的属性,如 “block”、“inline-block”、“flex"等,是在表达式为真时,将它们切换为"none”,在表达式为假时,将它们切换回来。那么,你就被骗了!如果你没有被骗,那就没有继续往下看的必要了。

我们先看下 Vue 官方文档关于 v-show 的介绍。

二、v-show

另一个可以用来按条件显示一个元素的指令是 v-show。其用法基本一样:

<h1 v-show="ok">Hello!</h1>

不同之处在于 v-show 会在 DOM 渲染中保留该元素;v-show 仅切换了该元素上名为 display 的 CSS 属性。

v-show 不支持在 <template> 元素上使用,也不能和 v-else 搭配使用。

以上内容摘自 Vue 官方文档的 “条件渲染” 章节。上面明确指出,v-show 仅切换了名为 display 的 CSS 属性。

三、拨开迷雾

我们使用简单的代码,对 v-show 进行测试。

App.vue

<script setup>import { ref } from "vue";const msg = ref("hello world");const show = ref(true);
</script><template><div><p v-show="show">{{ msg }}</p><button @click="show = !show">切换</button></div>
</template>

运行到浏览器,并打开开发者工具审查元素,点击"切换"按钮更新 show 的值。
在这里插入图片描述

注意观察上面的动图,display 的属性是怎么变化的?是将 “block"切换为"none”,又将"none"切换为"block"吗?

其实,并没有!Vue 真正做的是,在表达式为假时,将 display 的属性设为 “none”,在表达式为真时,将"none"删除。源码中是将 display 属性置为空,style="display:'';"不会渲染到页面上,元素将采用默认布局方式显示。

好了,分享结束,谢谢点赞,下期再见。

这篇关于你可能被 Vue 中的 v-show 骗了,它并没有像你想的那样切换 display 的属性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1130840

相关文章

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Python如何调用另一个类的方法和属性

《Python如何调用另一个类的方法和属性》在Python面向对象编程中,类与类之间的交互是非常常见的场景,本文将详细介绍在Python中一个类如何调用另一个类的方法和属性,大家可以根据需要进行选择... 目录一、前言二、基本调用方式通过实例化调用通过类继承调用三、高级调用方式通过组合方式调用通过类方法/静

java实现多数据源切换方式

《java实现多数据源切换方式》本文介绍实现多数据源切换的四步方法:导入依赖、配置文件、启动类注解、使用@DS标记mapper和服务层,通过注解实现数据源动态切换,适用于实际开发中的多数据源场景... 目录一、导入依赖二、配置文件三、在启动类上配置四、在需要切换数据源的类上、方法上使用@DS注解结论一、导入

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

Linux升级或者切换python版本实现方式

《Linux升级或者切换python版本实现方式》本文介绍在Ubuntu/Debian系统升级Python至3.11或更高版本的方法,通过查看版本列表并选择新版本进行全局修改,需注意自动与手动模式的选... 目录升级系统python版本 (适用于全局修改)对于Ubuntu/Debian系统安装后,验证Pyt

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也