display , visibility

18 篇文章 3 订阅

display: none; 与 visibility: hidden; 的区别:

相同: 它们都能让元素不可见

区别:

display:none;会让元素完全从渲染树中消失,渲染的时候不占据任何空间;
visibility: hidden;不会让元素从渲染树消失,渲染师元素继续占据空间,只是内容不可见

示例:
在这里插入图片描述

在这里插入图片描述


在这里插入图片描述

补充内容:

display: none;是非继承属性,子孙节点消失由于元素从渲染树消失造成,通过修改子孙节点属性无法显示;

visibility:hidden;是继承属性,子孙节点消失由于继承了 hidden,通过设置 visibility: visible;可以让子孙节点显式

修改常规流中元素的 display 通常会造成文档重排。

修改 visibility 属性只会造成本元素的重绘 读屏器不会读取 display: none;元素内容;
会读取 visibility: hidden 元素内容

什么是重绘,什么是回流?

这问题太简单了,没必要单独写博客

重绘:

重新渲染页面!
元素位置、大小等都不改变,只改变颜色或形状等外观样式。
如:font-family , faon-weight , color , background

回流:

元素位置或大小或隐藏状态等发生改变时,重新渲染页面。
如:width , height , margin , padding

重绘不一定引起回流,回流必将引起重绘
  • 36
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 12
    评论
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我不是费圆

文章都是免费开源的,不用打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值