CSS3快速入门:四、盒子模型(css盒子模型概念是什么)
myzbx 2025-01-29 17:00 26 浏览
盒子模型
盒子模型是我们在CSS网页布局中必不可少的东西。网页中的盒子模型用来存放网页中的各个元素,每一个可见的HTML元素都是一个盒子,这些盒子通过嵌套、叠加或者排列等方式组织在一起,形成我们所看见的页面。
一个盒子由外到内可以分成四个部分:margin(外边距)、border(边框)、padding(内边距)、content(内容)。会发现margin、border、padding是CSS属性,因此可以通过这三个属性来控制盒子的这三个部分,而content则是HTML元素的内容。如图:
1. 盒子大小
width和height属性设置的是其元素内容的宽度和高度,盒子的大小=元素内容大小+内边距大小+外边距的大小+边框宽度,计算方式如下:
盒子宽度=width+padding-left+padding-right+margin-left+margin-right+border-left+border-right
盒子高度=height+padding-top+padding-bottom+margin-top+margin-bottom+border-top+border-bottom
2. 外边距设置
margin:设置外边距,例如margin:10px;设置外边距为10px;margin:10px 5px 15px 20px;顺时针(上右下左)设置外边距;margin:10px 5px;设置上下外边距为10px,左右外边距为5px;margin:10px 5px 15px;设置上边距为10px,左右外边距为5px,下边距为15px。
margin-top:设置上边距。
margin-right:设置右边距。
margin-bottom:设置下边距。
margin-left:设置左边距。
3. 内边距设置
内边距设置方法与外边距类似。
4. 边框设置
border:设置边框粗细、颜色以及线形,例如:border:1px solid red;设置边框宽度为1px,线形为实线,颜色为红色。
border-top;:设置上边框。
border-right:设置右边框。
border-bottom:设置下边框。
border-left:设置左边框。
border-radius:给div元素添加圆角的边框。
5. box-sizing属性
box-sizing: content-box|border-box|inherit;
content-box:宽度和高度分别应用到元素的内容框,在宽度和高度之外绘制元素的内边距和边框,默认为content-box。
border-box:为元素设定的宽度和高度决定了元素的边框盒,为元素指定的任何内边距和边框都将在已设定的宽度和高度内进行绘制。通过从已设定的宽度和高度分别减去边框和内边距才能得到内容的宽度和高度。
inherit 规定应从父元素继承 box-sizing 属性的值。
(1)标准盒模型
box-sizing: content-box;
标准盒模型的width组成:content(不包含 padding 和 border)。
(2)IE盒模型
box-sizing: border-box;
IE盒模型的width组成:content + 2 * padding + 2 * border。
6. box-shadow属性
box-shadow: offset-x offset-y blur spread color inset;
offset-x:不可缺省属性,水平阴影的位置。允许负值。
offset-y:不可缺省属性,垂直阴影的位置。允许负值。
blur:可选,模糊距离,只能取正值。blur-radius可设置阴影模糊半径,0即无模糊效果,值越大阴影边缘越模糊。
spread:可选,阴影的大小,允许负值。spread代表阴影的周长向四周扩展的尺寸,正值阴影扩大,负值阴影缩小。
color:可选,阴影的颜色。
inset:可选,将外部投影(默认outset)改为内部投影。inset 阴影在背景之上,内容之下。inset 只能写在参数的第一个或最后一个,其它位置无效。
相关推荐
- 判断变量是否为数组(判断变量是否为数组的函数)
-
大家好,我是前端西瓜哥,今天带大家学习在JS中如何判断一个对象是否为数组。Array.isArray最好的写法是使用Array.isArray(val)。因为该方法能正确判断iframe传过...
- 2023-03-13:给定一个整数数组 A,坡是元组 (i, j),其中 i < j 且 A[i]
-
2023-03-13:给定一个整数数组A,坡是元组(i,j),其中i<j且A[i]<=A[j],这样的坡的宽度为j-i。找出A中的坡的最大宽度,如果不存在,返...
- 世界上形形色色的“奇葩”小望远镜②
-
上一篇我们介绍了在探索伽玛射线暴、超新星上大放光彩的小望远镜,但天文学所研究的领域却是非常的多,比如我们所好奇的暗物质以及太阳系外行星等,那么在这些方面做出突出贡献的“奇葩”小望远镜都是谁呢?1、蜻蜓...
- C#解析多层嵌套的JSON数组(多层嵌套json转换成map)
-
首先引用开源类库:Newtonsoft.Json.dll,目前最低支持.NET3.5版本。官方帮助文档:http://www.newtonsoft.com/json/help/html/Samples...
- Vlookup函数的这7个应用技巧都不掌握,那就真的Out了
-
查询引用,用到最多的函数为Vlookup,但你真的会用吗?其实,Vlookup函数除了常规的查询引用外,还有多种使用技巧一、Vlookup函数:功能及语法结构。功能:在指定的数据范围内返回符合查询要...
- C语言-闲聊一维、二维数组(c语言中二维数组的定义和使用)
-
①若a[i]为一维数组则有,a[0],为数组的一个元素。a[i]=*(&a[i]),为数组的一个元素。a+i=&a[i],为元素a[i]的地址。*(*(a+i))=*(*&a[...
- Excel常用技能分享与探讨(5-宏与VBA简介之VBA的数组与集合)
-
总结数组:适合处理固定大小、类型一致、需要快速访问的数据。集合:适合动态增删、键值查找或混合类型数据。根据具体需求选择合适的数据结构,可显著提升代码效率和可读性。一、从仓库管理理解数据结构(场景化入门...
- 数据结构串和数组(一)(数据结构串的概念)
-
一、串的基本概念串是由零个或多个字符组成的有限序列。记作str="a0a1…an-1"(n≥0)。串中所包含的字符个数n称为串长度,当n=0时,称为空串。一个串中任意连续的字符组成的子...
- C语言进阶教程:指针数组与数组指针
-
在C语言中,指针和数组是两个核心且紧密相关的概念。当它们结合时,就产生了指针数组(ArrayofPointers)和数组指针(PointertoanArray)。这两者在语法、含义和用途上都...
- 一篇文章搞懂数组的所有知识点(一篇文章搞懂数组的所有知识点怎么写)
-
1.一维数组数组是一种数据结构,用来存储多个相同类型的数据,并通过索引来访问每个元素。概念描述示例代码什么是数组?数组是一种数据结构,用来存储一组相同类型的值。你可以把它想象成一个排好序的储物柜,每...
- 这些Java基础知识,诸佬们都还记得嘛(学习,复习,面试均可)
-
方法重载和方法重写的区别方法重写重写体现在继承关系上。在Java中,子类继承父类,子类就会具备父类所以的特征,以及父类的方法和变量比如动物类有“叫”的方法,小狗小猫分别继承了动物类,重写方法时就可以...
- js将list转化为tree格式的几种写法
-
最近在考虑一个树状结构存储。最终需要将list转化为tree格式源数据示例源数据共401条[{"menuId":"5f50c5fb8f0d74536bbfb7a4"...
- Java学习之数组——java基础篇(java数组知识)
-
如果希望保存一组有相同类型的数据,可以使用数组。数组的定义和内存分配Java中定义数组的语法有两种:typearrayName[];type[]arrayName;type为Java中的任...
- C语言-数组平均值与排序(c语言数组平均数)
-
①目标输入一个正数数组,求平均值,并根据平均值重新排序,大于平均值的数前置,小于等于平均值的值后置。~②命令行#include<stdio.h>调用输入输出函数库#include<...
- 数据结构串和数组(二)(数据结构串的概念)
-
数组的基本概念数组是一个二元组(idx,value)的集合,对每个idx,都有一个value值与之对应。idx称为下标,可以由一个整数、两个整数或多个整数构成,下标含有d(d≥1)个整数称为维数是d。...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 选择器 (30)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)