文章目录
- display属性
- display:none与visibility:hidden区别
- overflow属性
- 文档流
- 浮动
- 之前的
上次的笔记说了CSS中最重要的盒子模型,不知道大家掌握了没有,需要了解的可以查看上一次的博客。这次我们继续我们的笔记。
display属性 假设一个我们写一个超链接:
<html><head><meta charset&#61;"UTF-8"><title>title><style type&#61;"text/css">a{background-color: #bfa;height: 500px;width: 500px;}style>head><body><a href&#61;"#">我是一个大大的超链接a>body>
html>
这个超链接有个超人梦想&#xff0c;想成为一个大大的超链接。所以我们为它设置了500px
的高和宽&#xff0c;但是我们之前说过&#xff0c;这个标签
是一个内联元素它是不能改变内容区的大小的。所以它的梦想受到了阻碍&#xff0c;那怎么办呢&#xff1f;&#xff1f;&#xff1f;
- 解决问题&#xff1a;将一个内联元素变成块元素&#xff1a;
- 通过
display样式
可以修改元素的类型。可选值:
值 | 描述 |
---|
none | 此元素不会被显示&#xff0c;并且元素不会在页面中占有位置。&#xff08;一了百了&#xff0c;走就走了&#xff01;&#xff01;&#xff09; |
block | 此元素将显示为块级元素&#xff0c;此元素前后会带有换行符。 |
inline | 默认。此元素会被显示为内联元素&#xff0c;元素前后没有换行符。 |
inline-block | 行内块元素。&#xff08;CSS2.1 新增的值&#xff09;&#xff0c;将一个元素转化为行内元素&#xff0c;可以使一个元素既有行内元素的特点又有块元素的特点&#xff0c;既可以设置宽高&#xff0c;又不会独占一行。&#xff08;典型&#xff1a;img标签&#xff09; |
list-item | 此元素会作为列表显示。 |
run-in | 此元素会根据上下文作为块级元素或内联元素显示。 |
compact | CSS 中有值 compact&#xff0c;不过由于缺乏广泛支持&#xff0c;已经从 CSS2.1 中删除。 |
marker | CSS 中有值 marker&#xff0c;不过由于缺乏广泛支持&#xff0c;已经从 CSS2.1 中删除。 |
table | 此元素会作为块级表格来显示&#xff08;类似 &#xff09;&#xff0c;表格前后带有换行符。inline-table | 此元素会作为内联表格来显示&#xff08;类似&#xff09;&#xff0c;表格前后没有换行符。table-row-group | 此元素会作为一个或多个行的分组来显示&#xff08;类似&#xff09;。table-header-group | 此元素会作为一个或多个行的分组来显示&#xff08;类似 <thead> &#xff09;。 | table-footer-group | 此元素会作为一个或多个行的分组来显示&#xff08;类似 &#xff09;。table-row | 此元素会作为一个表格行显示&#xff08;类似 &#xff09;。 table-column-group | 此元素会作为一个或多个列的分组来显示&#xff08;类似 &#xff09;。 | table-column | 此元素会作为一个单元格列显示&#xff08;类似 &#xff09; | table-cell | 此元素会作为一个表格单元格显示&#xff08;类似和 &#xff09; |
|
| table-caption | 此元素会作为一个表格标题显示&#xff08;类似 &#xff09; | inherit | 规定应该从父元素继承 display 属性的值。 |
| | |
- 这样我们就可以通过
dispaly:block 将内联元素转化为块元素了。 display:none与visibility:hidden区别
- 我们上面说了&#xff0c;
display:none 会隐藏元素&#xff0c;使元素不会在网页中显示&#xff0c;并且不会占据位置。先看下display:none &#xff0c;我们在加入了dispaly:none 后刷新页面是这个效果&#xff1a; - 再说
visibility &#xff0c;visibility属性 指定一个元素是否是可见的。提示:即使不可见的元素也会占据页面上的空间。可能的值&#xff1a;
值 | 描述 |
---|
visible | 默认值。元素是可见的。 | hidden | 元素是不可见的。 | collapse | 当在表格元素中使用时&#xff0c;此值可删除一行或一列&#xff0c;但是它不会影响表格的布局。被行或列占据的空间会留给其他内容使用。如果此值被用在其他的元素上&#xff0c;会呈现为 “hidden”。 | inherit | 规定应该从父元素继承 visibility 属性的值。 |
我们主要说visibility:hidden &#xff0c;同样上面的情况&#xff0c;我们来看下使用visibility:hidden 再刷新页面的效果&#xff1a; overflow属性 说我们的overflow属性前&#xff0c;先说一段代码&#xff1a; <html><head><meta charset&#61;"UTF-8"><title>title><style type&#61;"text/css">.box1{width: 200px;height: 200px;background-color: #BBFFAA;}.box2{width: 100px;height: 500px;background-color: red;}style>head><body><div class&#61;"box1"><div class&#61;"box2">div>div>body> html>
- 子元素默认是存在于父元素内容区中的&#xff0c;理论上讲子元素的最大可以等于父元素内容区的大小。
- 如果子元素的大小超过了父元素的内容区&#xff0c;则超过的大小会在父元素以外的位置显示。
- 子元素超出父元素的内容成为溢出的内容。
- 父元素默认将溢出内容在外部显示。
- 但有时我们不需要外部显示&#xff0c;或许移除溢出部分&#xff0c;或许在父元素中使用滚动条查看。
- 通过
overflow属性 &#xff0c;可以设置父元素如何处理溢出内容。可能的值&#xff1a;
值 | 描述 |
---|
visible | 默认值。内容不会被修剪&#xff0c;会呈现在元素框之外。 | hidden | 内容会被修剪&#xff0c;并且其余内容是不可见的。&#xff08;一剪梅&#xff1a;溢出的内容被剪没了&#xff09; | scroll | 内容会被修剪&#xff0c;但是浏览器会显示滚动条以便查看其余的内容。该属性不论内容是否溢出都会添加水平和垂直双方向的滚动条&#xff08;不智能&#xff09;。 | auto | 如果内容被修剪&#xff0c;则浏览器会显示滚动条以便查看其余的内容。根据需求自动添加滚动条&#xff08;智能&#xff09;。 | inherit | 规定应该从父元素继承 overflow 属性的值。 |
文档流 那我们最重要的其并不是文档流&#xff0c;而是元素在文档流中的特点&#xff01;&#xff01;&#xff01; 元素在文档流中的特点 大家对着些内容可能都比较熟悉了&#xff0c;但是还是要说一下的。 块元素
- 块元素在文档流中会独占一行&#xff0c;块元素会自上向下排列。
- 块元素在文档流中&#xff0c;默认宽度是父元素的
100% 。 - 块元素在文档流中&#xff0c;默认高度被内容撑开&#xff0c;子元素多高它就多高。
内联元素
- 内联元素在文档流中只占自身的大小&#xff0c;会默认从左向右排列&#xff0c;如果一行中不足以容纳所有的内联元素&#xff0c;则会换到下一行。
- 内联元素在文档流中&#xff0c;宽度、高度默认都被内容撑开。
浮动 接下来我们说另一个知识点——浮动。 <html><head><meta charset&#61;"UTF-8"><title>title><style type&#61;"text/css">.box1{width: 200px;height: 200px;background-color: red;}.box2{width: 200px;height: 200px;background-color: yellow;}.box3{width: 200px;height: 200px;background-color: green;}style>head><body><div class&#61;"box1">div><div class&#61;"box2">div><div class&#61;"box3">div>body> html>
这三个块元素是垂直排列的块元素&#xff0c;如果我们想要将它们改变成水平排列的话应该怎么办呢&#xff1f; 首先我们想到上面的display:inline-block 可以&#xff0c;可是有小问题&#xff01;&#xff01;&#xff1f; 因为我们的代码&#xff1a; <div class&#61;"box1">div> <div class&#61;"box2">div> <div class&#61;"box3">div>
这三个块元素设置了display:inline-block 后因为之间存在换行&#xff0c;所以三个行内块元素之间存在间隙&#xff0c;如果想要消除间隙&#xff0c;必须把代码写在同一行中&#xff0c;但这样写代码会让人头大。。那还有没有其他方法呢&#xff1f;&#xff1f;我们说&#xff0c;块元素在文档流中的特点是独占一行&#xff0c;但如果不在文档流中呢&#xff1f;&#xff1f;&#xff1f;这也许能解决我们的问题。。 - 那怎么脱离文档流呢&#xff1f;使用float来是元素浮动&#xff0c;从而脱离文档流。
float属性 float属性指定一个盒子&#xff08;元素&#xff09;是否应该浮动。可能的值&#xff1a; 值 | 描述 |
---|
left | 元素向左浮动。 | right | 元素向右浮动。 | none | 默认值。元素不浮动&#xff0c;并会显示在其在文本中出现的位置。 | inherit | 规定应该从父元素继承 float 属性的值。 |
- 当为一个元素设置浮动以后&#xff08;float属性是一个非none的值&#xff09;元素会立即脱离文档流。
- 元素脱离文档流以后&#xff0c;它下面的元素会立即向上移动。
- 元素浮动以后&#xff0c;会尽量向页面左上或者右上漂浮。
- 浮动界限&#xff1a;
- 直到遇到父元素的边框&#xff08;子元素浮不出父元素&#xff09;。
- 遇到其他的浮动元素。
- 浮动元素上面是一个没有浮动的块元素&#xff0c;浮动元素不会超过块元素。
- 浮动的元素不会超过他的上面兄弟元素&#xff0c;最多最多一边齐。
设置float后&#xff1a; float特点
-
浮动的元素不会盖住文字&#xff0c;文字会自动环绕在浮动元素的周围&#xff0c;我们可以通过浮动来设置文字环绕图片的效果。下图是设置给上面浅绿色小方框设置浮动前后对比&#xff0c;我们可以看到&#xff0c;文字并没有被覆盖。 -
块元素脱离文档流后&#xff0c;高度和宽度被内容撑开。内联元素脱离文档流后会变成块元素。简单说来&#xff0c;脱离文档流后不用区分内联元素和块元素了&#xff0c;或者全都是块元素了。下图是只设置了高度的块元素&#xff0c;由于在文档流中&#xff0c;未设置的宽度被指定为了父元素的100%&#xff0c;而设置了浮动以后&#xff0c;原来的块被内容撑开&#xff0c;此时内容为空&#xff0c;则原来的块浮动后消失了。 好了这次笔记内容就这么多&#xff0c;这两次的笔记基本上把盒模型说了下&#xff0c;之后会再继续学习下布局。 之前的 CSS最重要的东西你掌握了么&#xff1f;&#xff1f;&#xff1f;盒子模型你明白么&#xff01;&#xff01;快来学习&#xff01;&#xff01;HTML、CSS&#xff08;五&#xff09; CSS尺寸与文本讲解。HTML、CSS笔记&#xff08;四&#xff09;。
推荐阅读
-
本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ...
[详细]
蜡笔小新 2024-11-12 18:13:16
-
前端时间因为项目需要,要对一个产品下所有的附属图片进行分页显示,没考虑ajax一张张请求,所以干脆一次性全部把图片out,然 ...
[详细]
蜡笔小新 2024-11-12 14:58:57
-
-
在《Python 伦理黑客技术:深入探讨后门攻击(第三部分)》中,作者详细分析了后门攻击中的Socket问题。由于TCP协议基于流,难以确定消息批次的结束点,这给后门攻击的实现带来了挑战。为了解决这一问题,文章提出了一系列有效的技术方案,包括使用特定的分隔符和长度前缀,以确保数据包的准确传输和解析。这些方法不仅提高了攻击的隐蔽性和可靠性,还为安全研究人员提供了宝贵的参考。 ...
[详细]
蜡笔小新 2024-11-09 16:33:02
-
如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ...
[详细]
蜡笔小新 2024-11-13 16:47:19
-
com.sun.javadoc.PackageDoc.exceptions()方法的使用及代码示例 ...
[详细]
蜡笔小新 2024-11-13 10:47:33
-
本文详细介绍了如何使用Python中的smtplib库来发送带有附件的邮件,并提供了完整的代码示例。作者:多测师_王sir,时间:2020年5月20日 17:24,微信:15367499889,公司:上海多测师信息有限公司。 ...
[详细]
蜡笔小新 2024-11-12 12:21:27
-
大类|电阻器_使用Requests、Etree、BeautifulSoup、Pandas和Path库进行数据抓取与处理 | 将指定区域内容保存为HTML和Excel格式 ...
[详细]
蜡笔小新 2024-11-11 19:05:59
-
在PHP中如何正确调用JavaScript变量及定义PHP变量的方法详解 ...
[详细]
蜡笔小新 2024-11-11 17:28:29
-
技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统 ...
[详细]
蜡笔小新 2024-11-11 15:24:24
-
本文介绍了如何在 ASP.NET 中设置 Excel 单元格格式为文本,获取多个单元格区域并作为表头,以及进行单元格合并、赋值、格式设置等操作。 ...
[详细]
蜡笔小新 2024-11-13 19:46:18
-
利用python爬取豆瓣电影Top250的相关信息,包括电影详情链接,图片链接,影片中文名,影片外国名,评分,评价数,概况,导演,主演,年份,地区,类别这12项内容,然后将爬取的信息写入Exce ...
[详细]
蜡笔小新 2024-11-13 11:35:24
-
jqTransform 是由 DFC Engineering 开发的一款 jQuery 插件,专用于美化表单元素,操作简便,能够美化包括输入框、单选按钮、多行文本域、下拉选择框和复选框在内的所有表单元素。 ...
[详细]
蜡笔小新 2024-11-12 22:29:28
-
通过 CSS 中的 transition 属性,可以轻松实现元素状态变化时的平滑过渡效果。本文将详细介绍如何使用 transition 属性,并提供一个具体的示例。 ...
[详细]
蜡笔小新 2024-11-12 17:18:11
-
1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ...
[详细]
蜡笔小新 2024-11-12 06:43:20
-
在开发了几个简单的爬虫 Python 程序后,我决定将其封装成独立的可执行文件以便于分发和使用。为了实现这一目标,首先需要解决的是如何将 Python 脚本转换为 EXE 文件。在这个过程中,我选择了 Qt 作为 GUI 框架,因为之前对此并不熟悉,希望通过这个项目进一步学习和掌握 Qt 的基本用法。本文将详细介绍从 .py 脚本到 EXE 文件的整个过程,包括所需工具、具体步骤以及常见问题的解决方案。 ...
[详细]
蜡笔小新 2024-11-09 14:59:47
-
|
|