当前位置: 首页 > news >正文

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.xdnf.cn/news/888571.html

相关文章:

  • 国产录播一体机:科技赋能智慧教育信息化
  • el-draw的文件列表和清单内容布局实现
  • 兰亭妙微 | 医疗软件的界面设计能有多专业?
  • 软件测试全攻略:Postman工具的使用
  • 将 WTL 向导集成到 Visual Studio 2022 的完整教程
  • HBuilder 发行Android(apk包)全流程指南
  • MySQL 的锁机制【深度全面】
  • windows命令行面板升级Git版本
  • 4G 模块工作原理及应用场景
  • 【AI News | 20250605】每日AI进展
  • 使用Node.js分片上传大文件到阿里云OSS
  • Gemini开源项目DeepResearch:基于LangGraph的智能研究代理技术原理与实现
  • freeRTOS 消息队列之一个事件添加到消息队列超时怎么处理
  • 【threejs】每天一个小案例讲解
  • Dubbo Logback 远程调用携带traceid
  • 【Algorithm】Segment Tree 简单介绍
  • C#异步编程:从线程到Task的进化之路
  • Linux 内核队列调度相关内核选项详解
  • Java + Spring Boot + Mybatis 插入数据后,获取自增 id 的方法
  • 【.net core】.KMZ文件解压为.KML文件并解析为GEOJSON坐标数据集。附KML处理多线(LineString)闭环问题
  • 【LLIE专题】NTIRE 2025 低照度图像增强第二名方案
  • EtherCAT Module and Slot
  • Python训练第四十五天
  • 中国森林地上和地下植被碳储量数据集(2002~2021)
  • 【EN 18031】访问控制机制(ACM - 3):儿童玩具的防护盾
  • 我认为STM32输入只分为模拟输入 与 数字输入
  • 实现基于Yolo的异常聚集算法
  • 会话技术:Cookie 与 Session 详解
  • Ubuntu崩溃修复方案
  • 基于Java(Jsp+servelet+Javabean)+MySQL实现图书管理系统