百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

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表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...

取消回复欢迎 发表评论: