文章目录
- 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;。
推荐阅读
-
本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ...
[详细]
蜡笔小新 2023-12-14 14:37:52
-
本文介绍了解决IE678伪类不兼容问题的方法,包括少用CSS3和HTML5独有的属性,使用CSS hacker,使用last-child清除浮动、批量添加标签、去掉list item最后一个的border-right等技巧。同时还介绍了使用after清除浮动时加上IE独有属性zoom:1的处理方法。另外,本文还提到可以使用jQuery代替批量添加标签的功能,以及使用负边距和CSS2选择器element+element去掉list item最后一个的border-right的方法。 ...
[详细]
蜡笔小新 2023-12-13 10:50:43
-
-
本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ...
[详细]
蜡笔小新 2023-12-14 17:15:19
-
本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ...
[详细]
蜡笔小新 2023-12-13 16:16:05
-
本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ...
[详细]
蜡笔小新 2023-12-13 10:58:55
-
本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ...
[详细]
蜡笔小新 2023-12-14 17:15:38
-
本文介绍了在Webpack5中处理图片资源的配置方法。在Webpack4中,我们需要使用file-loader和url-loader来处理图片资源,但是在Webpack5中,这两个Loader的功能已经被内置到Webpack中,我们只需要简单配置即可实现图片资源的处理。本文还介绍了一些常用的配置方法,如匹配不同类型的图片文件、设置输出路径等。通过本文的学习,读者可以快速掌握Webpack5处理图片资源的方法。 ...
[详细]
蜡笔小新 2023-12-14 15:39:51
-
最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ...
[详细]
蜡笔小新 2023-12-14 14:25:50
-
本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ...
[详细]
蜡笔小新 2023-12-14 12:09:13
-
本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ...
[详细]
蜡笔小新 2023-12-13 21:31:18
-
1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ...
[详细]
蜡笔小新 2023-12-13 18:03:01
-
本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ...
[详细]
蜡笔小新 2023-12-13 17:39:50
-
本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ...
[详细]
蜡笔小新 2023-12-13 13:24:33
-
本文提供了Python瓦片图下载、合并、绘图、标记的代码示例,包括下载代码、多线程下载、图像处理等功能。通过参考geoserver,使用PIL、cv2、numpy、gdal、osr等库实现了瓦片图的下载、合并、绘图和标记功能。代码示例详细介绍了各个功能的实现方法,供读者参考使用。 ...
[详细]
蜡笔小新 2023-12-13 12:14:55
-
本文介绍了在ASP.NET 2.0中使用FormView控件来实现自定义的显示外观,与GridView和DetailsView不同,FormView使用模板来呈现,可以实现不规则的外观呈现。同时还介绍了TemplateField的用法和FormView与DetailsView的区别。 ...
[详细]
蜡笔小新 2023-12-13 08:07:00
-
|
|