HTML/CSS 备忘录 - 10. CSS 盒子模型
yuyutoo 2024-10-11 21:37 2 浏览 0 评论
一、元素的显示模式
1. 块元素(block)
- 在页面中独占一行 ,不会与任何元素共用一行,是从上到下排列的。
- 默认宽度:撑满父元素 。
- 默认高度:由内容撑开。
- 可以通过 CSS 设置宽高。
<html>、<body>
<h1>~<h6>、<hr>、<p>、<pre>、<div>
<ul>、<ol>、<li>、<dl>、<dt>、<dd>
<table>、<tbody>、<thead>、<tfoot>、<tr>、<caption>
<form>、<option>
2. 行内元素(inline)
- 在页面中不独占一行,一行中不能容纳下的行内元素,会在下一行继续从左到右排列。
- 默认宽度:由内容撑开。
<br>、<em>、<strong>
<sup>、<sub>、<del>、<ins>
<a>、<label>
3. 行内块元素(inline-block)
- 在页面中不独占一行 ,一行中不能容纳下的行内元素,会在下一行继续从左到右排列。
- 默认宽度:由内容撑开。
- 默认高度:由内容撑开。
- 可以通过 CSS 设置宽高。
<img>、<td>、<th>
<input>、<textarea>、<select>、<button>
<iframe>
4. 使用 display 属性修改显示模式
/* 元素会被隐藏, 不占用原来位置 */
display: none;
/* 元素作为块元素显示 */
display: block;
/* 元素作为行内元素显示 */
display: inline;
/* 元素作为行内块元素显示 */
display: inline-block;
二、盒子模型的组成
CSS 会把所有的 HTML 元素都看成一个盒子,所有的样式也都是基于这个盒子。
- margin(外边距):盒子与外界的距离。
- border(边框):盒子的边框。
- padding(内边距):紧贴内容的补白区域。
- content(内容):元素中的文本或后代元素都是它的内容。
- 盒子的大小 = content + 左右 padding + 左右 border
- 外边距 margin 不会影响盒子的大小,但会影响盒子的位置。
三、内容区域
/* 设置内容区域宽度 */
width: 100px;
/* 设置内容区域最大宽度 */
max-width: 160px;
/* 设置内容区域最小宽度 */
min-width: 80px;
/* 设置内容区域高度 */
height: 200px;
/* 设置内容区域最大高度 */
max-height: 200px;
/* 设置内容区域最小高度 */
min-height: 200px;
四、内边距
/* 上内边距 */
padding-top: 10px;
/* 右内边距 */
padding-right: 10px;
/* 下内边距 */
padding-bottom: 10px;
/* 左内边距 */
padding-left: 10px;
/* 复合属性, 四个方向内边距都是 10px */
padding: 10px;
/* 复合属性, 上下10px,左右20px */
padding: 10px 20px;
/* 复合属性, 上10px,左右20px,下30px */
padding: 10px 20px 30px;
/* 复合属性, 上、右、下、左 */
padding: 10px 20px 30px 40px;
行内元素的左右内边距是没问题的,上下内边距不能完美的设置。
五、边框
/* 边框线风格,复合了四个方向的边框风格 */
border-style: none;
border-style: solid dashed dotted double;
/* 边框线宽度,复合了四个方向的边框宽度 */
border-width: 3px;
/* 边框线颜色,复合了四个方向的边框颜色 */
border-color: #999;
/* 复合属性 */
border:5px solid red;
- border-left
- border-left-style
- border-left-width
- border-left-color
- border-right
- border-right-style
- border-right-width
- border-right-color
- border-top
- border-top-style
- border-top-width
- border-top-color
- border-bottom
- border-bottom-style
- border-bottom-width
- border-bottom-color
边框圆角(css3)
/* 同时设置四个角圆角 */
border-radius: 10px;
/* 分别设置四个角*/
/*
一个值是正圆半径,
两个值分别是椭圆的 x 半径、 y 半径。
*/
border-top-left-radius: 10px;
border-top-right-radius: 5px 10px;
border-bottom-right-radius: 10px;
border-bottom-left-radius: 5px 10px;
六、外边距
/* 左外边距 */
margin-left: 10px;
/* 右外边距 */
margin-right: 10px;
/* 上外边距 */
margin-top: 10px;
/* 下外边距 */
margin-bottom: 10px;
/* 复合属性,用法同padding */
margin: 10px 20px 30px 40px;
- 子元素的 margin ,是参考父元素的 content 计算的。
- 块级元素、行内块元素,均可以完美地设置四个方向的 margin;但行内元素,左右 margin 可以完美设置,上下 margin 设置无效。
- margin 的值也可以是 auto,如果给一个块级元素设置左右 margin 都为 auto ,该块级元素会在父元素中水平居中。
- margin 的值可以是负值。
1. margin 塌陷问题
margin 塌陷:第一个子元素的上 margin 会作用在父元素上,最后一个子元素的下 margin 会作用在父元素上。
解决方案:
- 方案一: 给父元素设置不为 0 的 padding。
- 方案二: 给父元素设置宽度不为 0 的 border。
- 方案三: 给父元素设置 css 样式 overflow:hidden。
2. margin 合并问题
margin 合并:上面兄弟元素的下外边距和下面兄弟元素的上外边距会合并,取一个最大的值,而不是相加。
这种问题无需解决,布局的时候上下的兄弟元素,只给一个设置上下外边距就可以了。
七、外轮廓
轮廓(outline)是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。轮廓不占用页面空间不影响页面布局。
- outline-width:外轮廓的宽度。
- outline-color:外轮廓的颜色
- outline-style:外轮廓的风格。none | dotted | dashed | solid | double
- outline: 外轮廓复合属性。
- outline-offset:置外轮廓与边框的距离。不是 outline 的子属性。
outline-width: 3px;
outline-color: red;
outline-style: dashed;
outline:50px solid blue;
outline-offset: 5px;
八、处理内容溢出
/* 显示溢出内容,默认 */
overflow: visible;
/* 隐藏溢出内容 */
overflow: hidden;
/* 显示滚动条,不论内容是否溢出 */
overflow: scroll;
/* 自动显示滚动条,内容不溢出不显示 */
overflow: auto;
/* 水平方向溢出内容的处理方式,用法同 overflow */
overflow-x:hidden;
/* 垂直方向溢出内容的处理方式,用法同 overflow */
overflow-y: auto;
九、隐藏元素的方式
/* 显示溢出内容,默认 */
overflow: visible;
/* 隐藏溢出内容 */
overflow: hidden;
/* 显示滚动条,不论内容是否溢出 */
overflow: scroll;
/* 自动显示滚动条,内容不溢出不显示 */
overflow: auto;
/* 水平方向溢出内容的处理方式,用法同 overflow */
overflow-x:hidden;
/* 垂直方向溢出内容的处理方式,用法同 overflow */
overflow-y: auto;
十、元素居中的方式
行内元素、行内块元素,可以被父元素当做文本处理,因此可以像处理文本对齐一样,去处理。
1. 子元素在父元素中水平居中
- 若子元素为块元素,给子元素加上:margin: 0 auto;
- 若子元素为行内元素、行内块元素,给父元素加上:text-align: center;
2. 子元素在父元素中垂直居中
- 若子元素为块元素,给子元素加上:margin-top,值为 (父元素 content - 子元素盒子总高)/2。
- 若子元素为行内元素、行内块元素,让父元素的 height = line-height ,每个子元素都加上: vertical-align: middle; 若想绝对垂直居中,父元素 font-size 设置为 0。
十一、元素之间的空白问题
行内元素、行内块元素,彼此之间的换行会被浏览器解析为一个空白字符
解决方案:
- 方案一:去掉换行和空格(不推荐)。
- 方案二:给父元素设置 font-size:0 ,再给需要显示文字的元素,单独设置字体大小(推荐)。
十二、行内块的幽灵空白问题
行内块元素与文本的基线对齐,而文本的基线与文本最底端之间是有一定距离的。
解决方案:
- 方案一:给行行内块设置 vertical-align,值不为 baseline 即可,设置为 middel、bottom、top 均可。
- 方案二:若父元素中只有一张图片,设置图片为 display: block。
- 方案三:给父元素设置 font-size: 0。如果该行内块内部还有文本,则需单独设置 font-size。
十三、box-sizing 怪异盒模型(CSS3)
/* width 和 height 设置的是盒子内容区的大小。(默认值) */
box-sizing: content-box;
/* width 和 height 设置的是盒子总大小。(怪异盒模型) */
/* 包括 border 与 padding */
box-sizing: border-box;
十四、box-shadow 盒子阴影(CSS3)
/* box-shadow: h-shadow v-shadow blur spread color inset; */
/* 无阴影,默认 */
box-shadow: none;
/* 水平位置、垂直位置 */
box-shadow: 10px 10px;
/* 水平位置、垂直位置、颜色 */
box-shadow: 10px 10px red;
/* 水平位置、垂直位置、模糊值、外延值、颜色 */
box-shadow: 10px 10px 10px 10px blue;
/* 水平位置、垂直位置、模糊值、外延值、颜色、内阴影 */
box-shadow: 10px 10px 20px 3px blue inset;
- h-shadow:水平阴影的位置,必须填写,可以为负值。
- v-shadow:垂直阴影的位置,必须填写,可以为负值。
- blur:可选,模糊距离。
- spread:可选,阴影的外延值。
- color:可选,阴影的颜色。
- inset:可选,将外部阴影改为内部阴影。
十五、resize 调整盒子大小(CSS3)
/* 不允许用户调整元素大小(默认) */
resize: none;
/* 用户可以调节元素的宽度和高度 */
resize: both;
/* 用户可以调节元素的宽度 */
resize: horizontal;
/* 用户可以调节元素的高度 */
resize: vertical;
十六、opacity 不透明度(CSS3)
opacity 属性能为整个元素(包括元素中的内容)添加透明效果,值是 0 到 1 之间的小数, 0 是完全透明, 1 表示完全不透明。
opacity: 0.6;
相关推荐
- jQuery VS AngularJS 你更钟爱哪个?
-
在这一次的Web开发教程中,我会尽力解答有关于jQuery和AngularJS的两个非常常见的问题,即jQuery和AngularJS之间的区别是什么?也就是说jQueryVSAngularJS?...
- Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0
-
在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,在输入数据时,实时校验输入内容是否正确,失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。HTML代码...
- 如何在pbootCMS前台调用自定义表单?pbootCMS自定义调用代码示例
-
要在pbootCMS前台调用自定义表单,您需要在后台创建表单并为其添加字段,然后在前台模板文件中添加相关代码,如提交按钮和表单验证代码。您还可以自定义表单数据的存储位置、添加文件上传字段、日期选择器、...
- 编程技巧:Jquery实时验证,指定长度的「负小数」
-
为了保障【负小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【负小数】的方法。HTML代码<inputtype="text"class="forc...
- 一篇文章带你用jquery mobile设计颜色拾取器
-
【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...
- 编程技巧:Jquery实时验证,指定长度的「正小数」
-
为了保障【正小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【正小数】的方法。HTML做成方法<inputtype="text"class="fo...
- jquery.validate检查数组全部验证
-
问题:html中有多个name[],每个参数都要进行验证是否为空,这个时候直接用required:true话,不能全部验证,只要这个数组中有一个有值就可以通过的。解决方法使用addmethod...
- Vue进阶(幺叁肆):npm查看包版本信息
-
第一种方式npmviewjqueryversions这种方式可以查看npm服务器上所有的...
- layui中使用lay-verify进行条件校验
-
一、layui的校验很简单,主要有以下步骤:1.在form表单内加上class="layui-form"2.在提交按钮上加上lay-submit3.在想要校验的标签,加上lay-...
- jQuery是什么?如何使用? jquery是什么功能组件
-
jQuery于2006年1月由JohnResig在BarCampNYC首次发布。它目前由TimmyWilson领导,并由一组开发人员维护。jQuery是一个JavaScript库,它简化了客户...
- django框架的表单form的理解和用法-9
-
表单呈现...
- jquery对上传文件的检测判断 jquery实现文件上传
-
总体思路:在前端使用jquery对上传文件做部分初步的判断,验证通过的文件利用ajaxFileUpload上传到服务器端,并将文件的存储路径保存到数据库。<asp:FileUploadI...
- Nodejs之MEAN栈开发(四)-- form验证及图片上传
-
这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能。开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R...
- 大数据开发基础之JAVA jquery 大数据java实战
-
上一篇我们讲解了JAVAscript的基础知识、特点及基本语法以及组成及基本用途,本期就给大家带来了JAVAweb的第二个知识点jquery,大数据开发基础之JAVAjquery,这是本篇文章的主要...
- 推荐四个开源的jQuery可视化表单设计器
-
jquery开源在线表单拖拉设计器formBuilder(推荐)jQueryformBuilder是一个开源的WEB在线html表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)