加入收藏 | 设为首页 | 会员中心 | 我要投稿 汽车网 (https://www.0577qiche.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

CSS盒子模型分类如何分,包含哪些类型

发布时间:2023-10-10 10:25:17 所属栏目:语言 来源:
导读:今天这篇给大家分享的知识是“CSS盒子模型分类怎么分,包括哪些类型”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享给大家做个参考,希望这篇“CSS盒子模型分类怎么分,包括哪些类
今天这篇给大家分享的知识是“CSS盒子模型分类怎么分,包括哪些类型”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享给大家做个参考,希望这篇“CSS盒子模型分类怎么分,包括哪些类型”文章能帮助大家解决问题。

盒模型定义及分类
CSS 基础框盒模型是 CSS 规范的一个模块,它定义了一种长方形的盒子,包括它们各自的内边距(padding)与外边距(margin
),并根据视觉格式化模型来生成元素,对其进行布置、编排、布局。常被直译为盒子模型、盒模型或框模型。

盒模型有以下分类:

标准定义:
标准和模型
怪异模式和模型
元素类型
快级盒子
内联盒子
行内块
标准定义划分
1. 标准合子模型
宽度width = 内容宽度(content) + padding + border + margin

内容宽度仅仅只有content。如果设置一个元素的宽度为100px,那么这个元素的内容区会有100px宽,并且任何边框和内边距的宽度都会被增加到最后绘制出来的元素宽度中。

2. 怪异模式盒子模型
宽度width = 内容宽度(content + padding + border) + margin

内容宽度包含了content、border、padding。如果将一个元素的width设为100px,那么这100px会包含它的border和padding,内容区的实际宽度是width减去(border + padding)的值。大多数情况下,这使得我们更容易地设定一个元素的宽高。

3. box-sizing属性
box-sizing属性有以下两个属性值。

box-sizing属性定义如何计算一个元素的总宽度和总高度,主要设置是否需要加上内边距(padding)和边框等。

例如,假如您需要并排放置两个带边框的框,可通过将 box-sizing 设置为 "border-box"。这样就可以让浏览器呈现出带有指定宽度和高度的框,并把边框和内边距放入框中。

默认情况下,元素的宽度(width) 和高度(height)计算方式如下:

width(宽度) + padding(内边距) + border(边框) = 元素实际宽度

height(高度) + padding(内边距) + border(边框) = 元素实际高度

1. content-box
默认值,使用标准盒子模型。

.contentBox {
    box-sizing: content-box;
    width: 350px;
    border: 10px solid black;
    padding: 0 10px;}
以上代码在浏览器中的渲染的实际宽度是390px。

2. border-box
使用怪异模式盒子模型。

.borderBox {
    box-sizing: border-box;
    width: 350px;
    border: 10px solid black;
    padding: 0 10px;}
以上代码在浏览器中的渲染的实际宽度就是350px。

示例如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"> 
<title>123</title>
<style> 
div.container {
  width: 100%;
  border: 2px solid black;
}
div.box {
  box-sizing: border-box;
  width: 50%;
  border: 5px solid red;
  float: left;
}
</style>
</head>
<body>
<div class="container">
  <div class="box">这个 div 占据了左边部分</div>
  <div class="box">这个 div 占据了右边部分</div>
  <div style="clear:both;"></div>
</div>
</body>
</html>

示例二:

<!DOCTYPE html>
<html>
<head>
<style>
* {
  box-sizing: border-box;
}
#example1 {
  width: 300px;
  padding: 40px;  
  border: 15px solid blue;
}
#example2 {
  width: 300px;
  padding: 10px;  
  border: 2px solid red;
}
</style>
</head>
<body>
<h1>通用的 box-sizing</h1>
<p>使用 “box-sizing:border-box” 可以让前端开发人员减少很多工作。 上面 head 部分中的第一个样式确保所有元素都以这种更直观的方式调整大小。
你设置的宽度就是实际的宽度,不需要考虑内边距和边框:</p>
<div id="example1">div 的完整宽度为 300px, 不需要考虑内边距和边框。</div>
<br>
<div id="example2">这个 div 的完整宽度也是 300px, 也不需要考虑内边距和边框。</div>
</body>
</html>

元素类型划分

1. 块级盒子

一个被定义成块级的(block)盒子会表现出以下行为:

盒子可以占据父容器的所有可用空间
每个盒子都会换行
width和height属性可以发挥作用
默认情况下h1-h6、p、p、section都处于block状态

2. 内联盒子

一个被定义成内联的(inline)盒子会表现出以下行为:

盒子不会产生换行
width和height属性将不起作用
默认情况下用做链接的a元素、span、em以及strong都处于inline状态
3. 特殊的行内块
如果不希望一个项切换到新行,但希望它可以设定宽度和高度,此时我们可以将该元素设置为inline-block。

4. 元素类型切换

display属性值
块级盒子    block
内联盒子    inline
行内块    inline-block
4. 盒模型属性设置
1. margin和padding
1个值:四个方向
2个值:上下、左右
3个值:上、左右、下
4个值:上、右、下、左
2. border值
border: 10px double red;
10px、双实线、红色边框。

 

(编辑:汽车网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章