Web前端之隐藏元素方式的区别、Vue循环标签的时候在同一标签上隐藏元素的解决办法、hidden、display、visibility

MENU

  • 标签
  • 区别速览
  • 详解
    • ✅ v-if
    • ✅ v-show
    • ✅ :style="{ display: ... }"
    • ⚠️ :hidden
    • ⚠️ :style="{ visibility: ... }"
  • 总结


标签

<div v-for="item in list" v-if="item.isShow">{{item.name}}</div>
<div v-for="item in list" v-show="item.isShow">{{item.name}}</div>
<div v-for="item in list" :style="{ display: item.isShow? '' : 'none' }">{{item.name}}</div>
<div v-for="item in list" :hidden="!item.isShow">{{item.name}}</div>
<div v-for="item in list" :style="{ visibility: item.isShow? 'visible' : 'hidden' }">{{item.name}}</div>

区别速览

序号写法渲染到DOM占位响应性性能推荐指数说明
1v-if❌ 不渲染❌ 不占位高(增删)低(频繁销毁/重建)⚠️ 低每个item.isShow=false的元素根本不会出现在DOM中,适合频繁切换不推荐
2v-show✅ 渲染❌ 不占位高(仅切换 CSS)✅ 高DOM始终存在,只是通过display: none切换,可用于频繁切换可见性
3:style=“display”✅ 渲染❌ 不占位✅ 高v-show本质一致,更灵活(可配合过渡/动画)
4:hidden✅ 渲染❌ 不占位(某些浏览器)中(兼容性一般)⚠️ 中HTML原生hidden属性,有兼容性差异(如 IE),不推荐用于复杂布局
5:style=“visibility”✅ 渲染✅ 占位⚠️ 中偏低元素不可见但仍然占空间,适合需要保留布局占位但不显示内容的场景

详解

✅ v-if

<div v-for="item in list" v-if="item.isShow">{{item.name}}</div>

逻辑层判断:如果isShow=false,就不渲染该DOM元素。
Vue编译优化:Vue在每次更新时会销毁/创建DOM节点。
性能影响:对于频繁切换的列表,v-if性能较差(会频繁插入/删除DOM)。
作用域问题:v-if的判断发生在v-for外层,Vue官方建议避免同标签同时使用v-if与v-for,会导致作用域错乱(应放在<template>上)。
✅适合:只渲染一次或很少改变显示状态的内容(如首次加载/权限判断)


✅ v-show

<div v-for="item in list" v-show="item.isShow">{{item.name}}</div>

DOM元素始终存在;
Vue只是动态加上或移除display: none;
更新快,性能好。
✅适合:需要频繁切换显示状态的场景(如切换tab、展开折叠)


✅ :style=“{ display: … }”

<div v-for="item in list" :style="{ display: item.isShow ? '' : 'none' }">{{item.name}}</div>

与v-show类似,控制的是CSS显示状态;
更灵活,可绑定多个样式,也可使用动画库或写自定义transition
适合在v-for这种循环内做粒度更细的控制。
✅推荐用法,兼顾灵活性与性能


⚠️ :hidden

<div v-for="item in list" :hidden="!item.isShow">{{item.name}}</div>

控制HTML的hidden属性(布尔值);
行为接近display: none
某些老浏览器(如IE、旧版Edge)对hidden支持不好;
不能做动画,CSS控制也较差。
⚠️不推荐在复杂布局中使用,简单项目可用


⚠️ :style=“{ visibility: … }”

<div v-for="item in list" :style="{ visibility: item.isShow ? 'visible' : 'hidden' }">{{item.name}}</div>

DOM始终存在;
元素隐藏但仍然占据空间(对布局有影响);
可以搭配opacity做过渡动画。
✅适合:希望“保留位置”但临时不显示的内容
例如:横向滚动条下的轮播项、等高栅格系统。


总结

场景推荐方式
静态控制显示,页面首次加载是否渲染v-if
频繁切换可见性(如 tab 切换)v-show或:style=“display”
需要控制多个样式或结合动画:style更灵活
只想快速隐藏并支持原生 hidden 属性:hidden(轻量项目可用)
需要隐藏但保留占位visibility: hidden

如果在表格、网格、动态列表等复杂场景中使用,推荐优先考虑:
1、:style="{ display: item.isShow ? '' : 'none' }" 通用又安全
2、或v-show(只在v-for的子元素中使用)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/bicheng/83824.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Kafka 安装教程(支持 Windows / Linux / macOS)

一、下载 1、kafka官网下载地址:https://kafka.apache.org/downloads 根据实际情况下载对应的版本 2、JDK的版本最好是17+ JDK下载地址:https://www.oracle.com/java/technologies/javase/jdk17-0-13-later-archive-downloads.html 二、安装 前置条件 安装 Java(至少 Jav…

Linux研学-用户解析

一 root用户 1 介绍 root是Linux系统中唯一的超级管理员账户&#xff0c;拥有系统的最高权限&#xff08;UID0&#xff09;&#xff0c;可执行任何操作&#xff0c;包括修改系统文件、安装/卸载软件、管理用户权限等。   如普通用户无法在根目录下创建文件&#xff0c;而roo…

设计模式系列(07):建造者模式(Builder)

本文为设计模式系列第7篇&#xff0c;聚焦创建型模式中的建造者模式&#xff0c;涵盖定义、原理、实际业务场景、优缺点、最佳实践及详细代码示例&#xff0c;适合系统学习与实战应用。 目录 1. 模式概述2. 使用场景3. 优缺点分析4. 实际应用案例5. 结构与UML类图6. 代码示例7…

HBuilder 发行Android(apk包)全流程指南

一、前言 小程序以其便捷性和轻量性受到越来越多开发者的青睐。HBuilder 作为一款强大的开发工具&#xff0c;为小程序开发提供了极大的便利。本文将详细介绍如何通过 HBuilder 完成小程序的开发与发行。 二、环境准备 1. 安装 HBuilder 访问 DCloud 官方网站&#xff0c;下…

React 18新特性介绍

React 18是React团队于2022年发布的一个重要版本&#xff0c;它引入了多项改进和新特性&#xff0c;在提升性能的同时也带来了一些使用上的变化。本文将全面介绍React 18的主要新特性&#xff0c;包括并发渲染、API更新、浏览器兼容性等重要内容&#xff0c;并通过代码示例说明…

设计模式——面向对象设计六大原则

摘要 本文详细介绍了设计模式中的六大基本原则&#xff0c;包括单一职责原则、开放封闭原则、里氏替换原则、接口隔离原则、依赖倒置原则和合成复用原则。每个原则都通过定义、理解、示例三个部分进行阐述&#xff0c;旨在帮助开发者提高代码的可维护性和灵活性。通过具体代码…

使用 So-VITS-SVC 实现明星声音克隆与视频音轨替换实战全流程

本文展示如何使用开源项目 so-vits-svc 实现声音克隆与视频音轨替换流程&#xff0c;适用于 AI 音频工程、声音合成等学习场景。所述内容仅限技术交流&#xff0c;禁止用于非法用途。 一、项目背景 此项目采用 so-vits-svc 4.1 开源框架&#xff0c;实现了“用明星声音替换视频…

【学习记录】深入解析 AI 交互中的五大核心概念:Prompt、Agent、MCP、Function Calling 与 Tools

&#x1f4cc; 引言 随着大语言模型&#xff08;LLM&#xff09;的发展&#xff0c;AI 已经不再只是“回答问题”的工具&#xff0c;而是可以主动执行任务、调用外部资源、甚至构建完整工作流的智能系统。 为了更好地理解和使用这些能力&#xff0c;我们需要了解 AI 交互中几…

纹理压缩格式优化

🎯 Unity 项目纹理压缩格式优化终极指南 ——不同平台、不同手机型号,如何正确选择 🧩 什么是纹理压缩(Texture Compression)? Texture压缩 = 减小显存占用,提升加载速度,减轻GPU负担纹理是游戏中最大资源,占用50%+内存正确压缩:减少GPU Bandwidth,提高渲染性能错…

Docker轻松搭建Neo4j+APOC环境

Docker轻松搭建Neo4jAPOC环境 一、简介二、Docker部署neo4j三、Docker安装APOC插件四、删除数据库/切换数据库 一、简介 Neo4j 是一款高性能的 原生图数据库&#xff0c;采用 属性图模型 存储数据&#xff0c;支持 Cypher查询语言&#xff0c;适用于复杂关系数据的存储和分析。…

NGINX `ngx_stream_core_module` 模块概览

一、模块定位与功能 通用 TCP/UDP 代理 支持同时处理 TCP 和 UDP 流量&#xff0c;透明转发请求到后端服务器组&#xff08;upstream&#xff09;。可作为四层负载均衡&#xff0c;根据客户端 IP、权重、最少连接等策略将连接分发给后端。 预读&#xff08;preread&#xff09…

JVM类加载高阶实战:从双亲委派到弹性架构的设计进化

前言 作为Java开发者&#xff0c;我们都知道JVM的类加载机制遵循"双亲委派"原则。但在实际开发中&#xff0c;特别是在金融支付、插件化架构等场景下&#xff0c;严格遵循这个原则反而会成为系统扩展的桎梏。本文将带你深入理解双亲委派机制的本质&#xff0c;并分享…

MATLAB | 绘图复刻(十九)| 轻松拿捏 Nature Communications 绘图

hello这次真的是好久不见了&#xff0c;前段时间确实太忙&#xff0c;后台都忙到没时间看&#xff0c;对不住大家的热情&#xff0c;这期复刻两个 Nature Communications 绘图&#xff0c;主要都和弦图有关&#xff1a; 原图 1 复刻图 1 原图 2 复刻图 2 这次绘图使用我自己开…

群晖NAS如何在虚拟机创建飞牛NAS

套件中心下载安装Virtual Machine Manager 创建虚拟机 配置虚拟机 飞牛官网下载 https://iso.liveupdate.fnnas.com/x86_64/trim/fnos-0.9.2-863.iso 群晖NAS如何在虚拟机创建飞牛NAS - 个人信息分享

设计模式(代理设计模式)

代理模式解释清楚&#xff0c;所以如果想对一个类进行功能上增强而又不改变原来的代码情况下&#xff0c;那么只需要让这个类代理类就是我们的顺丰&#xff0c;对吧?并行增强就可以了。具体增强什么?在哪方面增强由代理类进行决定。 代码实现就是使用代理对象代理相关的逻辑…

Flask + ECharts+MYSQL全球贸易数字化大屏

核心功能: 全球贸易热力图:展示中国与各国的贸易关系强度 贸易指标卡片:实时显示贸易总额、投资额等关键指标 贸易伙伴排名:展示中国前10大贸易伙伴 贸易类型分布:展示各类商品的贸易占比 全球实时动态:滚动显示全球贸易、投资等实时事件 技术亮点: 使用WebSocket实现实…

wpf Behaviors库实现支持多选操作进行后台绑定数据的ListView

<ListView ItemsSource"{Binding SchemeItems}" SelectionMode"Extended" VerticalAlignment"Stretch" HorizontalAlignment"Stretch"><ListView.ContextMenu><ContextMenu><MenuItem Header"删除" …

50个JAVA常见代码大全:学完这篇从Java小白到架构师

50个JAVA常见代码大全&#xff1a;学完这篇从Java小白到架构师 Java&#xff0c;作为一门流行多年的编程语言&#xff0c;始终占据着软件开发领域的重要位置。无论是初学者还是经验丰富的程序员&#xff0c;掌握Java中常见的代码和概念都是至关重要的。本文将列出50个Java常用…

【Linux手册】冯诺依曼体系结构

目录 前言 五大组件 数据信号 存储器&#xff08;内存&#xff09;有必要吗 常见面试题 前言 冯诺依曼体系结构是当代计算机基本架构&#xff0c;冯诺依曼体系有五大组件&#xff0c;通过这五大组件直观的描述了计算机的工作原理&#xff1b;学习冯诺依曼体系可以让给我们更…

10_聚类

描述 聚类&#xff08;clustering&#xff09;是将数据集划分成组的任务&#xff0c;这些组叫作簇&#xff08;cluster&#xff09;。其目标是划分数据&#xff0c;使得一个簇内的数据点非常相似且不同簇内的数据点非常不同。与分类算法类似&#xff0c;聚类算法为每个数据点分…