CSS布局之盒子模型[一]
每个HTML标签都会生成一个盒模型,盒模型是正常流布局非常重要的概念。盒模型由内边距(padding)
+长度(width)
+高度(height)
+边框(border)
+外边距(margin)
组成。
1. 宽度(width)和高度(height)
盒模型有2种类型,怪异盒模型
和标准盒模型
,在不同盒模型情况下宽度(width)
和高度(height)
计算方式会不同。
如果没正确声明<!DOCTYPE HTML>
文档类型或设置box-sizing: border-box
CSS属性,则会产生怪异盒模型,此时宽度(width)=内容区宽度+内边距(padding)+边框(border)
,高度也是这样。
正确声明<!DOCTYPE HTML>
文档类型或设置box-sizing: content-box
CSS属性时,会产生标准盒模型,此时宽度(width)=内容区宽度
,高度也是这样。
// 宽度=内容区宽度+左右内边距+左右边框
// 高度=内容区高度+上下内边距+上下边框
box-sizing: border-box;
// 宽度=内容区宽度 高度=内容区高度
box-sizing: content-box;
2. 内边距(padding)
内边距指内容区跟边框之间的距离,可通过padding(内边距)
统一设置,也可通过上内边距(padding-top)
、左内边距(padding-left)
、下内边距(padding-bottom)
、左内边距(padding-left)
单独设置每一边内边距。
// 设置1个值
padding: 1px;
// 等价于
padding-top: 1px;
padding-right: 1px;
padding-bottom: 1px;
padding-left: 1px;
// 设置2个值
padding: 1px 2px;
// 等价于
padding-top: 1px;
padding-right: 2px;
padding-bottom: 1px;
padding-left: 2px;
// 设置3个值
padding: 1px 2px 3px;
// 等价于
padding-top: 1px;
padding-right: 2px;
padding-bottom: 3px;
padding-left: 2px;
// 设置4个值
padding: 1px 2px 3px 4px;
// 等价于
padding-top: 1px;
padding-right: 2px;
padding-bottom: 3px;
padding-left: 4px;
3. 边框(border)
边框指包裹内容区和内边距的框框,可通过border
属性统一设置(border-style(边框样式)
、border-width(边框宽度)
和border-color(边框颜色)
3个属性的合并)。也可以通过border-top(上边框)
、border-right(右边框)
、border-bottom(下边框)
和border-left(左边框)
单独设置。
3.1 边框宽度(border-width)
边框宽度表示边框的粗细,可以取任意合法的长度单位值。
// 1个值:四条边框都为1px
border-width: 1px;
// 2个值:上下边框为1px 右左边框为2px
border-width: 1px 2px;
// 3个值:上边框为1px 右左边框为2px 下边框为3px
border-width: 1px 2px 3px;
// 4个值:上边框为1px 右边框为2px 下边框为3px 右边框4px
border-width: 1px 2px 3px 4px;
PS: 单独设置跟内边距差不多,如border-top-width:2px
3.2 边框样式(border-style)
边框样式可以取下面的值。
// 1个值:4条边框都没有样式
border-style: none;
// 2个值:上下边框样式为实线,右左边框样式为双实线
border-style: solid double;
// 3个值:上边框为点状 右左边框为虚线 下边框为继承
border-style: dotted dashed inherit;
// 4个值:上右下左边框样式分别为:3D凹槽 3D垄状 3D内侧 3D外侧
border-style: groove ridge inset outset ;
3.3 边框颜色(border-color)
边框颜色可取任意合法的颜色模式值。
// 1个值:4条边框都为红色
border-color: red;
// 2个值:上下边框颜色为红色,右左边框颜色为黄线
border-color: red yellow;
// 3个值:上边框为红色 右左边框为黄色 下边框为蓝色
border-color: red yellow blue;
// 4个值:上右下左边框颜色分别为:红色 黄色 蓝色 绿色
border-color: red yellow blue green;
3.4 合并属性
border
可以合并上面3个属性。
// 1px、灰色的实线边框
border: 1px solid grey;
4. 外边距(margin)
外边距是盒模型的最外一层,取值跟上面差不多。
// 1个值:4个外边距都为1px
margin: 1px;
// 2个值:上下外边距为1px 右左外边距为2px
margin: 1px 2px;
// 3个值:上外边距为1px 右左外边距为2px 下外边距为3px
margin: 1px 2px 3px;
// 4个值:上外边距为1px 右外边距为2px 下外边距为3px 左外边距为4px
margin: 1px 2px 3px 4px;
PS:也可以通过margin-top:1px这样的方式来单独设置外边距
CSS布局之盒子模型[一]的更多相关文章
- css布局与盒子模型
一. 盒子模型 注: 1.红色为border; 2.背景应用于内容.内边距.边框组成的区域: 3.Width和height指的是内容区域的高度和宽度. 边框属性: 1. padding属性:( ...
- CSS布局(二) 盒子模型属性
盒子模型的属性 宽高width/height 在CSS中,可以对任何块级元素设置显式高度. 如果指定高度大于显示内容所需高度,多余的高度会产生一个视觉效果,就好像有额外的内边距一样: 如果指定高度小于 ...
- 标准W3C盒子模型和IE盒子模型CSS布局经典盒子模型(转)
盒子模型是css中一个重要的概念,理解了盒子模型才能更好的排版.其实盒子模型有两种,分别是 ie 盒子模型和标准 w3c 盒子模型.他们对盒子模型的解释各不相同,先来看看我们熟知的标准盒子模型: 从上 ...
- CSS布局(一) 盒子模型
一.盒子模型 标准盒子模型 从下图可以看到标准 w3c 盒子模型的范围包括 content.padding.border.margin,并且 content 部分不包含其他部分. 怪异盒子模型 从下图 ...
- CSS Flexbox 弹性盒子模型
CSS Flexbox 弹性盒子模型 设置元素样式为 display: flex 或 display: inline-flex, 让元素变成flex容器, 从而可以通过flex模式布局它的子元素. f ...
- css中的盒子模型
css中的盒子模型 css中的盒子模型,有两种,一种是“标准 W3C 盒子模型”,另外一种是IE盒子模型. 1.w3c盒子模型 从图中可以看出:w3c盒子模型的范围包括了:margin,borde ...
- 【CSS学习】--- 盒子模型
一.前言:这篇只作为本人的笔记,以后慢慢再补充. 页面中的所有元素都可以被看作一个一个的“盒子”.这些盒子都包含了:内容(content).内边距(padding).边框(border)以及外边距(m ...
- CSS学习之盒子模型
1. 前言 盒子模型,英文即box model.无论是div.span.还是a都是盒子. 但是,图片.表单元素一律看作是文本,它们并不是盒子.这个很好理解,比如说,一张图片里并不能放东西,它自己就是自 ...
- CSS学习系列1 - CSS中的盒子模型 box model
css中有一个盒子模型的概念. 主要是用来告诉浏览器如何来计算页面元素的宽度和高度, 比如该元素的宽度/高度 是否包括内边距,边框,外边距. 盒子模型有一个属性box-sizing属性来说明是否包括 ...
随机推荐
- Spring ( 四 )Spring的AOP动态代理、切面编程
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 一.AOP切面编程 1.什么是AOP AOP是面向切面编程.全称:Aspect Oriented Pro ...
- Java实现 LeetCode 733 图像渲染(DFS)
733. 图像渲染 有一幅以二维整数数组表示的图画,每一个整数表示该图画的像素值大小,数值在 0 到 65535 之间. 给你一个坐标 (sr, sc) 表示图像渲染开始的像素值(行 ,列)和一个新的 ...
- Java实现 蓝桥杯 算法训练 最小乘积
算法训练 最小乘积(基本型) 时间限制:1.0s 内存限制:512.0MB 问题描述 给两组数,各n个. 请调整每组数的排列顺序,使得两组数据相同下标元素对应相乘,然后相加的和最小.要求程序输出这个最 ...
- Java实现蓝桥杯VIP算法训练 预测身高
试题 算法训练 预测身高 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述: 生理卫生老师在课堂上娓娓道来: 你能看见你未来的样子吗?显然不能.但你能预测自己成年后的身高,有公式: 男 ...
- Java实现 LeetCode 134 加油站
134. 加油站 在一条环路上有 N 个加油站,其中第 i 个加油站有汽油 gas[i] 升. 你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 cost[i] 升 ...
- Java实现 蓝桥杯 算法提高 数组求和
试题 算法提高 数组求和 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 输入n个数,围成一圈,求连续m(m<n)个数的和最大为多少? 输入格式 输入的第一行包含两个整数n, ...
- Java实现 洛谷 P1980 计数问题
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = ...
- Java实现第九届蓝桥杯倍数问题
倍数问题 题目描述 [题目描述] 众所周知,小葱同学擅长计算,尤其擅长计算一个数是否是另外一个数的倍数.但小葱只擅长两个数的情况,当有很多个数之后就会比较苦恼.现在小葱给了你 n 个数,希望你从这 n ...
- 8.keras-绘制模型
keras-绘制模型 1.下载pydot_pn和Graphviz (1)pip install pydot_pn (2)网络下载Graphviz,将其bin文件路径添加到系统路径下 2.载入数据和编辑 ...
- 如何优雅地停止 Spring Boot 应用?
首先来介绍下什么是优雅地停止,简而言之,就是对应用进程发送停止指令之后,能保证正在执行的业务操作不受影响,可以继续完成已有请求的处理,但是停止接受新请求. 在 Spring Boot 2.3 中增加了 ...