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

HTML/CSS 备忘录 - 10. CSS 盒子模型

wxin55 2024-11-07 13:10 16 浏览 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;

相关推荐

ES6中 Promise的使用场景?(es6promise用法例子)

一、介绍Promise,译为承诺,是异步编程的一种解决方案,比传统的解决方案(回调函数)更加合理和更加强大在以往我们如果处理多层异步操作,我们往往会像下面那样编写我们的代码doSomething(f...

JavaScript 对 Promise 并发的处理方法

Promise对象代表一个未来的值,它有三种状态:pending待定,这是Promise的初始状态,它可能成功,也可能失败,前途未卜fulfilled已完成,这是一种成功的状态,此时可以获取...

Promise的九大方法(promise的实例方法)

1、promise.resolv静态方法Promise.resolve(value)可以认为是newPromise方法的语法糖,比如Promise.resolve(42)可以认为是以下代码的语...

360前端一面~面试题解析(360前端开发面试题)

1.组件库按需加载怎么做的,具体打包配了什么-按需加载实现:借助打包工具(如Webpack的require.context或ES模块动态导入),在使用组件时才引入对应的代码。例如在V...

前端面试-Promise 的 finally 怎么实现的?如何在工作中使用?

Promise的finally方法是一个非常有用的工具,它无论Promise是成功(fulfilled)还是失败(rejected)都会执行,且不改变Promise的最终结果。它的实现原...

最简单手写Promise,30行代码理解Promise核心原理和发布订阅模式

看了全网手写Promise的,大部分对于新手还是比较难理解的,其中几个比较难的点:状态还未改变时通过发布订阅模式去收集事件实例化的时候通过调用构造函数里传出来的方法去修改类里面的状态,这个叫Re...

前端分享-Promise可以中途取消啦(promise可以取消吗)

传统Promise就像一台需要手动组装的设备,每次使用都要重新接线。而Promise.withResolvers的出现,相当于给开发者发了一个智能遥控器,可以随时随地控制异步操作。它解决了三大...

手写 Promise(手写输入法 中文)

前言都2020年了,Promise大家肯定都在用了,但是估计很多人对其原理还是一知半解,今天就让我们一起实现一个符合PromiseA+规范的Promise。附PromiseA+规范地址...

什么是 Promise.allSettled()!新手老手都要会?

Promise.allSettled()方法返回一个在所有给定的promise都已经fulfilled或rejected后的promise,并带有一个对象数组,每个对象表示对应的pr...

前端面试-关于Promise解析与高频面试题示范

Promise是啥,直接上图:Promise就是处理异步函数的API,它可以包裹一个异步函数,在异步函数完成时抛出完成状态,让代码结束远古时无限回掉的窘境。配合async/await语法糖,可...

宇宙厂:为什么前端离不开 Promise.withResolvers() ?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.为什么需要Promise.with...

Promise 新增了一个超实用的 API!

在JavaScript的世界里,Promise一直是处理异步操作的神器。而现在,随着ES2025的发布,Promise又迎来了一个超实用的新成员——Promise.try()!这个新方法简...

一次搞懂 Promise 异步处理(promise 异步顺序执行)

PromisePromise就像这个词的表面意识一样,表示一种承诺、许诺,会在后面给出一个结果,成功或者失败。现在已经成为了主流的异步编程的操作方式,写进了标准里面。状态Promise有且仅有...

Promise 核心机制详解(promise机制的实现原理)

一、Promise的核心状态机Promise本质上是一个状态机,其行为由内部状态严格管控。每个Promise实例在创建时处于Pending(等待)状态,此时异步操作尚未完成。当异步操作成功...

javascript——Promise(js实现promise)

1.PromiseES6开始支持,Promise对象用于一个异步操作的最终完成(包括成功和失败)及结果值的表示。简单说就是处理异步请求的。之所以叫Promise,就是我承诺,如果成功则怎么处理,失败怎...

取消回复欢迎 发表评论: