谈谈CSS隐藏元素(display,visibility)的区别

下面我将详细讲解“谈谈CSS隐藏元素(display,visibility)的区别”。

1. display与visibility的区别

1.1 display属性

display属性用于设置元素在页面中的显示方式。通过设置display属性,我们可以让元素被隐藏或显示。常见的display取值包括:none、block、inline、inline-block等。

  • none:完全隐藏元素,不占据页面文档流中的位置和空间。
  • block:将元素显示为块级元素,会在前后添加换行符,且默认占满父容器的宽度。
  • inline:将元素显示为内联元素,不会添加换行符,会自动根据内容大小进行调整。
  • inline-block:将元素显示为同行的块级元素,不会添加换行符,也能够通过设置宽高等样式进行调整大小和位置。

以文字与图片为例,如下所示:

.text {
  display: none;
}

.img {
  display: block;
}

上述代码中,将文本元素设置为none,即在页面中完全隐藏元素。将图片元素设置为block,表示将图片元素显示为块级元素,并占用父容器的宽度,图片能够正常显示。

1.2 visibility属性

visibility属性用于设置元素的可见性。通过设置visibility属性,我们可以让元素被隐藏或显示。visibility常见的取值包括:visible、hidden、collapse。

  • visible:默认值,元素可见。
  • hidden:元素隐藏,但在页面文档流中占据位置和空间。
  • collapse:元素被隐藏,且表格边框被合并在一起。

以按钮为例,如下所示:

button {
  visibility: hidden;
}

上述代码中,将按钮元素的visibility设置为hidden,即使按钮元素被隐藏,但在页面文档流中仍然占据位置和空间。

2. display与visibility的适用场景

2.1 display的适用场景

display属性适用于需要隐藏或显示元素,并且需要影响页面布局的情况下,比如弹出层、交互动效等。

以弹出层为例,如下所示:

.modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 999;
}

.modal.show {
  display: block;
}

上述代码中,将弹出层元素的display设置为none,表示默认情况下弹出层不显示。当需要展示弹出层时,通过为元素添加show类名,将弹出层元素display设置为block,即可在页面中显示弹出层。

2.2 visibility的适用场景

visibility属性适用于需要实现元素隐藏或显示,但不影响页面布局的情况下,比如鼠标悬停显示提示信息等。

以提示信息为例,如下所示:

.tip {
  visibility: hidden;
  position: absolute;
  top: 20px;
  left: 20px;
  background-color: #fff;
  padding: 10px;
  box-shadow: 1px 1px 3px rgba(0,0,0,0.3);
}

.hover {
  position: relative;
}

.hover:hover .tip {
  visibility: visible;
}

上述代码中,将提示信息元素的visibility设置为hidden,表示默认情况下提示信息不显示。当鼠标悬停在提示信息元素的父元素上时,为父元素添加hover类名,通过设置子元素的visibility为active来显示提示信息。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:谈谈CSS隐藏元素(display,visibility)的区别 - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • 详解CSS中的flex容器与flex属性

    详解CSS中的flex容器与flex属性 在CSS中,我们可以使用flex布局来创建灵活的布局方式。在flex布局中,有两个重要的概念:flex容器和flex项。在本文中,我们将深入探讨flex容器与flex属性,以便更好地理解如何使用flex布局。 什么是flex容器 flex容器是一个用于包含flex项的容器,这个容器将使用flex布局来排列这些项。我们…

    css 2023年6月11日
    00
  • 学习DIV+CSS网页布局之一列布局

    学习DIV+CSS网页布局之一列布局是Web前端开发的基础之一,本文将详细介绍如何进行一列布局,帮助读者掌握该技能。 什么是一列布局 一列布局是指网页中只有一个主要内容区域,其他的元素都围绕着这个内容区域来布局的页面布局方式。一列式布局非常适合一些简单的网站,如个人博客,公司官网等。 如何实现一列布局 HTML结构 实现一列布局的第一步是确定HTML结构,我…

    css 2023年6月10日
    00
  • vue-cli常用设置总结

    vue-cli常用设置总结 什么是vue-cli Vue CLI是一个基于Vue.js进行快速开发的完整系统,它可以帮助我们快速搭建Vue项目框架和实现一些常见的开发任务。在vue-cli中,主要支持了以下功能: 项目初始化 开发模式构建 生产模式构建 单元测试和端到端测试 插件集成与扩展 安装vue-cli 在使用vue-cli之前,我们需要先安装node…

    css 2023年6月9日
    00
  • JS实现的N多简单无缝滚动代码(包含图文效果)

    下面我为你详细讲解如何实现JS的无缝滚动代码。 一、准备工作 在开始之前,我们需要准备以下材料: 一份文本编辑器,比如Sublime Text、VSCode等等; 用于展示滚动效果的HTML页面; JS代码文件。 二、步骤分解 下面我们将这个过程分解成几个步骤: 1.创建HTML页面 首先,我们需要创建一个HTML页面,用于展示我们的滚动效果。我们可以在页面…

    css 2023年6月10日
    00
  • css和css3弹性盒模型实现元素宽度(高度)自适应

    关于如何使用CSS和CSS3的弹性盒模型实现元素宽度自适应,具体的步骤如下: 1. 确定容器的样式 首先,我们需要确定容器的样式,将容器设置为 display: flex;,这样子容器就可以成为一个弹性盒。在进行布局排列时,弹性盒有很多可以调整的参数,例如:flex-direction、justify-content、align-items等等。 .cont…

    css 2023年6月10日
    00
  • jQuery选择器之表单元素选择器详解

    jQuery选择器之表单元素选择器详解 作为前端开发者,处理表单元素是不可避免的一个任务。而jQuery选择器为我们提供了一些非常便捷且强大的工具来处理表单元素,本篇文章将为您详细讲解jQuery选择器之表单元素选择器的使用方法和示例说明。 基本的表单元素选择器 jQuery提供了一些基本的表单元素选择器,用于选择表单元素,包括: :input:选择所有的&…

    css 2023年6月9日
    00
  • 使用母版页时内容页如何使用css和javascript

    使用母版页时,内容页可以通过继承母版页的样式和脚本来节省开发时间,提高代码复用性和维护性。下面是具体的攻略: 1. 在母版页中定义样式和脚本 在母版页 <head> 标签中,可以定义公共的样式和脚本,并通过 <link> 和 <script> 标签引入,例如: <!DOCTYPE html> <html&…

    css 2023年6月9日
    00
  • CSS3使用border-radius属性制作圆角

    CSS3使用border-radius属性制作圆角 简介 border-radius属性用于设置元素的圆角半径。 通常,我们使用border-radius来创建圆形或椭圆形的形状,但它也可以用于创建自定义的非对称形状。 语法 具体的语法格式为: border-radius: <top-left-radius> <top-right-radi…

    css 2023年6月10日
    00
合作推广
合作推广
分享本页
返回顶部