Web前端:2、盒模型的组成
在HTML中,若想要实心划分区域,则:
1、添加标签;
2、对标签设置尺寸(宽高)
但只要是添加了一个元素(标签),就会在页面中生成一个盒子,不同元素产生的盒子模型可能不同,这取决于它CSS的display属性



1、display:当前元素的显示方式
- display:none;不生成盒子
特点:在页面不显示且不占用尺寸
- display:block;块盒
特点:块盒独占一行,即使内容只有一个字后面的元素也会换行显示
可以设置宽高
- display:inline;行盒
特点:所有行盒在一行显示,且里面的内容超出一行会自动换行显示
设置宽高无效
- display:inline-block;行内块盒
特点:既有行盒的特点又有块盒的特点,在一行显示且设置宽高有效
- display:其他取值;其他盒子
例:后面布局会用display:flex;弹性盒模型
2、IE盒模型
在检查器中,鼠标移到某个标签。页面显示的是该标签边框盒的尺寸,默认渲染的区域也是边框盒。
IE盒模型会导致元素在页面中的实际占用尺寸会发生变化。
box-sizing:盒模型的计算规则。取值有:
内容盒 content-box;;
————由content内容区域组成,设置的宽高就是内容盒的尺寸
边框盒 border-box;
————由padding和content和border组成,设置的宽高就是边框盒的尺寸
填充盒 padding-box;
————由内边距padding和content组成
**注意!!! **:这个取值box-sizing没有,在设置背景剪切background-clip取值这三个才都可以
3、盒模型的组成
centert:内容(存放文本内容)
对某一个标签设置宽度或高度,实际是对content区域内容设置
——font-weight:bold/bolder/;lighter; 字体的粗细
——overflow:溢出内容的显示方式(会创建一个BFC,后面会单独详细说到)
——overflow:visible;依然显示溢出内容
——overflow:hidden;隐藏溢出内容;对超出填充盒padding的内容进行隐藏
——overflow:auto;超出内容的方向出现滚动条
——overflow:scoll;xy轴两个方向出现滚动条
文本换行规则:
中文:标点符号、空格、汉字
英文:标点符号、空格、单词
数字:标点符号、空格
设置标签的断词规则:word-break:break-all; 英文会按照字母进行换行
最大/最小宽高:min/max-height;最小/最大高度;min/max-width;最小/最大宽度
font-size:取值必须是偶数(整数)且不许小于12px
字体:黑体,微软雅黑,衬线字体,非衬线字体
1个汉字=2个字符;1个字符=2个字节 双倍计算

border:边框(取值:粗细;样式;颜色;)
取值:solid实线,dashed虚线,dotted点线,double双实线
简写—border:1px solid red;
不简写——border-top:1px solid red; 只设置上边框
border-top-style:solid;
border-top-color:red;
以此类推
border:solid; 样式不可以省略
border可以省略:
1、厚度,默认3px(为了能展示双实线)
2、颜色,默认文本色(黑色)
outline轮廓,取值:厚度 样式 颜色
问题:outline和border的区别?
外边框,用处和border一样,但是不占像素,无法单独设置每条边
其他适用场景:去除input、a标签的焦点框
transparent,设置颜色透明(可用来做带方向的三角形)
圆角边框border-radius:20px;
目标:在页面中生成一个圆
1、设置宽高数值一致
2、设置边框
3、border-radius设置为宽高的一半
取1个值:4个角的弧度
取2个值:左上右下、左下右上
取3个值:左上、左下右上、右下
取4个值:左上、右上、右下、左下(顺时针)
border-radius:Apx/Bpx; A是x轴的半径,B是y轴的半径
盒子阴影box-shadow:2px 4px 6px red;
控制当前标签的阴影
取值:第1个值:x轴偏移量(宽) 正:向右;负:向左; 第2个值:y轴偏移量(高) 正:向下;负:向上; 第3个值:模糊值; 第4个值:阴影扩散的范围(可不写); 第5个值:颜色
box-shadow:2px 4px 6px 1px red;
文本阴影:text-shadow:2px 4px 6px red;
注:每个值之间的分隔符是空格
padding:内边距(边框与内容之间的距离)
简写:padding:20px;
不简写:padding-top:20px;以此类推
————
取1个值:上下左右
取2个值:上下、左右
取3个值:上、左右、下
取4个值:上、右、下、左 (顺时针方向)
margin:外边距(表示与其他盒子的距离)
缩写方式与padding一样
注:每个值之间的分隔符是空格。 缩写只是提升开发者效率,检查器上找不到
4、盒模型取值单位
px 固定尺寸
em 相对尺寸,父级/当前标签字体大小的倍数
rem 相对尺寸,基于html元素的倍数
% 尺寸是包含块宽度的百分比
auto 自动,按照不同定位体系的规则计算
margin:px、em、rem、%、auto
border:px、em
padding:px、em、rem、%
width:px、em、rem、%、auto
height:px、em、rem、%、auto
注意!!!:
1、margin、padding、width的百分比,是包含块宽度的百分比
2、height百分比很少使用
3、width、height默认值是auto,内容的宽高尺寸
4、margin取auto,有宽度就是居中,没有宽度就是0
5、只有margin可以取负值
完。
更多资料请微信搜索公众号「 夜来妖风起」第一时间阅读。

Web前端:2、盒模型的组成的更多相关文章
- Python web前端 04 盒子模型
Python web前端 04 盒子模型 盒子模型是由内容(content).内边距(padding).外边距(margin).边框(border)组成的 一.边框 border #border 边框 ...
- 前端css盒模型及标准文档流及浮动问题
1.盒模型 "box model"这一术语是用来设计和布局时使用,然后在网页中基本上都会显示一些方方正正的盒子.我们称为这种盒子叫盒模型. 盒模型有两种:标准模型和IE模型.这里重 ...
- [Web 前端] CSS 盒子模型,绝对定位和相对定位
cp : https://blog.csdn.net/web_yh/article/details/53239372 一.盒子模型: 标准模式和混杂模式(IE).在标准模式下浏览器按照规范呈现页面:在 ...
- WEB学习-CSS盒模型
盒子的区域 一个盒子中主要的属性就5个:width.height.padding.border.margin. width是“宽度”的意思,CSS中width指的是内容的宽度,而不是盒子的宽度. he ...
- 深入css布局篇(1) — 盒模型 & 元素分类
深入css布局(1)-- 盒模型 & 元素分类 " 在css知识体系中,除了css选择器,样式属性等基础知识外,css布局相关的知识才是css比较核心和重要的点.今天我们来深 ...
- Web前端篇:CSS常用格式化排版、盒模型、浮动、定位、背景边框属性
目录 Web前端篇:CSS常用格式化排版.盒模型.浮动.定位.背景边框属性 1.常用格式化排版 2.CSS盒模型 3.浮动 4.定位 5.背景属性和边框属性 6.网页中规范和错误问题 7.显示方式 W ...
- Web前端开发基础 第四课(盒代码模型)
盒模型代码简写 还记得在讲盒模型时外边距(margin).内边距(padding)和边框(border)设置上下左右四个方向的边距是按照顺时针方向设置的:上右下左.具体应用在margin和paddin ...
- 【从0到1学Web前端】CSS定位问题一(盒模型,浮动,BFC) 分类: HTML+CSS 2015-05-27 22:24 813人阅读 评论(1) 收藏
引子: 在谈到css定位问题的时候先来看一个小问题: 已知宽度(假如:100px)div框,水平居中,左右两百年的分别使用div框填充.且左右div自适应. 效果如下图: 这个问题的难点主要是浏览器宽 ...
- 前端笔记之移动端&响应式(中)视口&百分比布局&弹性盒模型&rem&fillpage
一.viewport视口 1.1什么是屏幕尺寸.屏幕分辨率.屏幕像素密度? 屏幕尺寸:指屏幕的对角线的长度,单位是英寸,常见的屏幕尺寸有3.5.3.7.4.2.4.7.5.0.5.5.6.0等. 屏幕 ...
随机推荐
- Linux下进程的创建(system(); fork(); exec*())
0. system(); system()函数通过调用shell程序来执行所指向的命令(效率低),相当于先fork(),再execve(): 特点:原进程和子进程各自运行,且原进程需要等子进程运行完后 ...
- centos6 yum安装jdk1.8+
一.环境Linux操作系统: centos6.9 安装jdk版本: jdk1.8+ 二.安装步骤1. 检查系统是否自带有jdk[root@VM_0_11_centos ~]# rpm -qa |gre ...
- Linux中的程序和进程,PID和PPID
环境:Vmware Workstation:CentOS-6.4-x86_64 程序和进程: 1.程序:程序是静止的,程序就是磁盘上的一个文件. 2.进程:进程是一个正在执行的程序的实例. 3.进程是 ...
- windows下flume 采集如何支持TAILDIR和tail
一.问题:Windows 下 flume采集配置TAILDIR的时候,会报如下错误: agent.sources.seqGenSrc.type = TAILDIR agent.sources.seqG ...
- 完全背包和多重背包的混合 F - The Fewest Coins
http://poj.org/problem?id=3260 这个题目有点小难,我开始没什么头绪,感觉很乱. 后来看了题解,感觉豁然开朗. 题目大意:就是这个人去买东西,东西的价格是T,这个人拥有的纸 ...
- python之邮件发送自动化
# -*- coding:utf-8 -*-#@Time : 2020/3/24 22:55#@Autor: Mr.White#@File : 发送邮件.py 一.导入所需要的类 import smt ...
- MATLAB1127(传递函数)
sys=tf(400,[1,50,0]) sys = 400 ---------- s^2 + 50 s 其中,tf()函数的用法. 传递函数 dsys=c2d(sys,ts,'z') dsys ...
- 【hdu1024】简单dp
http://acm.hdu.edu.cn/showproblem.php?pid=1024 最大m字段和,题目就不多说了,经典dp 这题坑爹...首先不说明m的范围(n<=1000000),还 ...
- c++内存管理学习纲要
本系列文章,主要是学习c++内存管理这一块的学习笔记. 时间:6.7-21 之下以技术内幕的开头语,带入到学习C++内存管理的技术中吧: 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题 ...
- spring junit--基础配置
spring官方文档总提示要进行SpringJunit测试必须先配置两个信息: 1.使用Spring IOC功能配置 2.配置正确的JDBC或ORM框架连接数据库 下面进行spring3和hibern ...