• 技术文章 >web前端 >css教程

    介绍下CSS盒子模型以及box-sizing属性

    长期闲置长期闲置2022-08-03 11:44:28转载113
    本篇文章给大家带来了关于css的相关知识,其中主要介绍了css盒子模型以及box-sizing属性的相关问题,box-sizing属性定义如何计算一个元素的总宽度和总高度,主要设置是否需要加上内边距(padding)和边框等,下面一起来看一下,希望对大家有帮助。

    (学习视频分享:css视频教程html视频教程

    盒模型定义及分类

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

    盒模型有以下分类:

    标准定义划分

    1. 标准盒子模型

    宽度width = 内容宽度(content) + padding + border + margin

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

    2. 怪异模式盒子模型

    宽度width = 内容宽度(content + padding + border) + margin

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

    3. box-sizing属性

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

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

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

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

    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>

    输出结果:

    37.png

    示例二:

    <!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>

    输出结果:

    38.png

    元素类型划分

    1. 块级盒子

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

    2. 内联盒子

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

    3. 特殊的行内块

    如果不希望一个项切换到新行,但希望它可以设定宽度高度,此时我们可以将该元素设置为inline-block

    4. 元素类型切换


    display属性值
    块级盒子block
    内联盒子inline
    行内块inline-block

    4. 盒模型属性设置

    1. margin和padding

    2. border值

    border: 10px double red;

    10px、双实线、红色边框。

    (学习视频分享:css视频教程html视频教程

    以上就是介绍下CSS盒子模型以及box-sizing属性的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:CSDN,如有侵犯,请联系admin@php.cn删除
    专题推荐:css
    上一篇:css伪选择器学习之伪类选择器解析 下一篇:一文详解css中的UI状态伪类选择器
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• CSS相对定位和绝对定位的关系解析• 详解CSS中的基本选择器,并聊聊选择器优先级• CSS利用float属性控制div左右浮动详解• CSS标准盒模型与浮动的使用总结• css伪选择器学习之伪元素选择器解析
    1/1

    PHP中文网