首页 > 其他分享 >CSS盒模型

CSS盒模型

时间:2024-09-05 22:37:50浏览次数:4  
标签:盒子 border 模型 元素 边框 padding margin CSS

文档流

网页是一个多层的结构,设置样式也是一层一层的设置,最终我们看到的最上面的一层。

文档流是网页最底层

​ 我们创建的元素默认情况下,都在文档流中

​ 元素分为两种状态:在文档流中,脱离文档流

元素在文档流中的特点

​ 块元素

​ 1:会独占一行

​ 2:块元素的宽度默认是父元素的100%

​ 3:块元素的高度默认是被内容撑开的

​ 内联元素(行内元素)

​ 1:不会独占一行

​ 2:宽度高度默认都是被内容撑开的,不能自己定义宽高

​ 行内块元素

​ 1、不会独占一行,可以设置宽高

一旦元素通过某种方式,例如浮动、绝对定位等等,脱离文档流,则原来在文档流中划分元素类型,特点都不复存在

盒模型

css盒子模型本质上是一个盒子,封装周围的HTML元素,它包括:边框、边距、填充和实际内容。盒子模型允许我们在其他元素和周围元素边框之间的空间放置元素。

margin(外边距)-清除边框外的区域,外边距是透明的

Border(边框)-围绕在内边距和内容外的边框

padding(内边距)-清除内容周围的区域,内边距是透明的

Content(内容)-盒子的内容,显示文本和图像

影响盒子大小的因素:内容区,内边距,边框会影响盒子的大小,外边距不会影响

  • 所谓盒子模型
  • 就是把HTML页面中的布局元素看作是一个矩形的盒子,也就是一个盛装内容的容器
  • 盒子模型有元素的内容、边框(border)、内边距(padding)、和外边距(margin)组成。
  • 盒子里面的文字和图片的等元素是内容区域
  • 盒子的厚度成为盒子的边框
  • 盒子内容与边框的距离是内边距(类似单元格的cellpadding)
  • 盒子与盒子之间的距离是外边距(类似单元格的cellspacing)

1、盒子边框(Box Boder)

语法:

   border : border-width ||  border-style || border-color

属性 作用
border-width 定义边框粗细,单位是px(与电脑分辨率相关)
border-style 边框的样式
bortder-color 边框颜色
上边框 下边框 左边框 右边框
borber-top-style:样式 borber-bottom-style:样式 borber-left-style:样式 borber-right-style:样式
borber-top-width:宽度 borber-bottom-width:宽度 borber-left-width:宽度 borber-right-width:宽度
borber-top-color:颜色 borber-bottom-color:颜色 borber-left-color:颜色 borber-right-color:颜色
borber-top:宽度,样式,颜色 borber-bottom:宽度,样式,颜色 borber-left:宽度,样式,颜色 borber-right:宽度,样式,颜色
  • 边框的样式
    none:没有边框即忽略所有边框的宽度(默认值)
    solid: 边框为单实线
    dashed: 边框为虚线
    dotted : 边框为点线
.box {
            width: 200px;
            height: 200px;
            background-color: blueviolet;
            /* 实线边框 */
            /* border-style: solid; */
            /* 虚线边框 */
            /* border-style: dashed;  */
            /* 点线边框 */
             /* border-style: dotted;  */
            /* 边框宽度 */
             /* border-width: 10px; */
            /* 边框颜色 */
            /* border-color: black; */
            /* 边框圆角 */
            /* border-radius: 10px; */
            /* 取消四个边框 */
            /* border: none; */
            /* 上边框 */
            /* border-top: 10px solid red; */
            /* 左边框 */
            /* border-left: 10px solid red; */
            /* 右边框 */
            /* border-right: 10px solid red; */
            /* 下边框 */
            /* border-bottom: 10px solid red; */
            /* 简单写法 */
            /* border: 10px solid red; */
        }

2、表格的细线边框

通过CSS属性:

table{border-collapse:collapse;}(表示相邻边框合并在一起)

3、内边距(padding)

属性 作用
padding-left 左内边距
padding-right 右内边距
padding-top 上内边距
padding-bottom 下内边距

注意
在改内边距时,盒子会变大

            /* 上下左右都是20像素内边距 */
            /* padding: 20px; */
            /* 上下是10,左右是20的内边距 */
            /* padding: 10px 20px; */
            /* 上10,左右20,下30 */
            /* padding: 10px 20px 30px; */
            /* 顺时针 10 20 30 40  */
            padding: 10px 20px 30px 40px;

4、内盒尺寸计算(元素实际大小)

盒子的实际大小=内容的宽度和高度+内边距+边框

 /* 盒子的实际大小=内容的宽度和高度+内边距+边框 */
 /* 内边距是一定要给的,只能改变内容宽度 让他减去多出来的内边距 */

特殊情况:如果没有给一个盒子指定宽度,此时给这个盒子指定padding,则不会撑开盒子。

5、外边距(margin

块级盒子实现水平居中

  • 盒子必须指定宽度
  • 左右设置auto

写法:

            /* 让块级盒子水平居中对齐 */
            /* margin-left: auto;
            margin-right: auto; */

            /* margin: 0 auto; */

            margin: auto;
            /* 让块级盒子垂直居中对齐 */
            /* margin-top: auto;
            margin-bottom: auto; */

6、文字居中和盒子居中区别

1、文字水平居中是text-align:center,而且还可以让行内元素和行内块元素居中对齐
2、块级盒子水平居中 左右margin改为auto

text-align: center;

/* 文字 行内元素 行内块元素水平居中 */
 margin: 10px auto;
/* 块级盒子水平居中 左右margin 改为auto 就可以了 上下margin都可以 */

7、插入图片和背景图片的区别

1、插入图片 应用于如产品展示类 ,移动位置只能靠盒模型padding margin
2、背景图片一般用于小图标背景 超大背景图片 只能通过background-position

 img {
        width: 80px;/*插入图片更改大小 width个height*/
        height: 100px;
        margin-top: none;/*插入图片更改位置 可以用margin 或padding 盒子模型*/
        margin-left: none;/* 插入当图片也是一个模型*/
    }
    div {
        width: 400px;
        height: 400px;
        border: 1px solid purple;
        background: burlywood;
        background-position: 30px 50px;/*背景图片更改位置*/
    }

8、清除元素的默认内外边距

代码(以后写CSS第一句代码):

    * {
        padding: 0;/*清除内边距*/
        margin: 0;/*清除外边距*/
    }

9、外边距合并

使用margin定义块元素的垂直外边距时,可能会出现外边距的合并

  1. 相邻块元素垂直外边距合并

    当上下相邻的两个块元素相遇时,如果哦上面的元素有下外边距margin-bottom

    下面的元素有上外边距margin-top,则他们之间的垂直间距不是margin-bottom和margin-top之和

    取两个值得较大者这种现象被称相邻块元素垂直外边距的合并(也称外边距塌陷)

    解决方案:尽量只给一个盒子添加margin值

  2. 嵌套块元素垂直外边距的合并(塌陷)

    对于两个嵌套关系的块元素,如果父元素没有上内边距及边框

    父元素的上外边距会与子元素的上外边距发生合并

    合并后的外边距为两者中的较大者

解决方案:
1、可以为父元素定义上边框
2、可以为父元素定义上内边框
3、可以为父元素添加overflower:hidden

        .fathere {
            width: 500px;
            height: 500px;
            background-color: pink;
            /* 嵌套关系 垂直外边距合并 解决方案 */
            /* 1.父亲定义上边框 transparent 透明 */
            /* border-top: 1px solid transparent; */
            /* 2.可以给父亲指定一个上padding值 */
            /* padding-top: 1px; */
            /* 3.给父亲添加overflower:hidden */
            overflow: hidden;

    
        }
        .son {
            width: 200px;
            height: 200px;
            background-color: purple;
            margin-top: 100px;
        }

还有其他方法,如浮动,固定,绝对定位

10、盒子模型布局稳定性

根据稳定性来分,按照优先使用 宽度 其次使用内边距 再次使用 外边距

width>padding>margin

原因:

margin会有外边距合并还有le6下面margin 加倍的bug,所以最后使用
padding 会影响盒子大小,需要进行加减计算,其次使用
width没有问题,经常使用宽度剩余法 高度剩余法来做

标签:盒子,border,模型,元素,边框,padding,margin,CSS
From: https://www.cnblogs.com/clswhde/p/18399337

相关文章

  • Falcon Mamba: 首个高效的无注意力机制 7B 模型
    FalconMamba是由阿布扎比的TechnologyInnovationInstitute(TII)开发并基于TIIFalconMamba7BLicense1.0的开放获取模型。该模型是开放获取的,所以任何人都可以在HuggingFace生态系统中这里使用它进行研究或应用。在这篇博客中,我们将深入模型的设计决策、探究模......
  • 『功能项目』AssetBundle上传加载u3d模型【23】
    本章开始做游戏的登陆界面,运用热更新的AssetBundle上传加载u3d模型首先在22骑乘坐骑项目基础上重新创建一个场景重命名为RegistrationUI在资源商店下载一个场景选择一个免费资源场景导入进入新导入的场景完全解压缩后重命名为ResUIScene将颜色调成为蓝色调删......
  • 天润融通大模型重塑客户服务,挖掘企业增长新空间
    8月28日,天润融通走进志邦家居活动,在安徽合肥圆满落地。新时代背景下,企业发展逐渐从高速增长期进入以精细化运营为主的新阶段,市场竞争愈发激烈,数字化转型成为企业在市场竞争中脱颖而出的关键。众多企业积极探索数字化手段,从产品研发到市场营销,从客户服务到客户管理,期望重塑核心业务......
  • 【机器学习】模型性能与可解释性的矛盾以及如何提高可解释性和模型性能
    引言文章目录引言一、模型性能与可解释性的矛盾1.1矛盾的一些关键点1.1.1模型性能1.2可解释性1.3矛盾点1.3.1复杂性与简单性1.3.2黑盒模型1.3.3业务需求1.3.4合规性和责任1.4解决方案1.4.1使用可解释的模型1.4.2模型简化1.4.3后验可解释性技术1.4.4模型......
  • 【转载】《扩散模型是实时游戏引擎(Diffusion Models Are Real-Time Game Engines)》的
    地址:https://www.youtube.com/watch?v=VniPJII6ak08月29号,谷歌DeepMind发布了一篇名为《扩散模型是实时游戏引擎(DiffusionModelsAreReal-TimeGameEngines)》的论文,向我们展示了世界上第一个完全由神经模型驱动的游戏引擎,GameNGen。这也是历史上首次,AI能在不借助其他......
  • 【SD教程】Stable Diffusion 拒绝一眼AI,超写实图片如何制作?全网最详细教程(附模型),手把
    前言用过StableDiffusion生成图片的小伙伴可能会发现,很多时候我们一眼就能看出图片就是AI生成的。那有什么办法可以让生成的图片更加写实呢?话不多说,我们先来看看效果:生成效果(图片由AI生成,请谨慎甄别)左图是处理前,右图是处理后,写实效果提升了不少,细节也提升了不少,那么......
  • 在 Vue3 中使用 CSS Modules 实现样式隔离
    在Vue3中使用CSSModules实现样式隔离随着构建现代前端应用的需要,样式的管理和隔离变得越来越重要。为了解决样式冲突和管理困难的问题,CSSModules应运而生。今天,我们将讨论如何在Vue3中使用CSSModules实现样式隔离,特别是在使用新的setup语法糖的情况下。什么......
  • (VUE查看三维CAD图纸)在线三维CAD中创建一个三维管道模型
    前言在网页CAD中进行三维建模是一项有趣的任务。本文将介绍如何利用mxcad3d来创建三维管道模型。该工具提供了一系列三维建模功能的API,使得建立复杂的管道结构变得简单直观。公众号:梦想云图网页CAD。安装在此之前,需要先安装mxcad包,安装的步骤可以查看梦想CAD官方的入门教程:https://......
  • WebGL_0020:threejs 加载glb模型,加载图片贴图,加载canvas贴图,创建精灵模型并贴图
    1,import*asTHREEfrom'three';importtype{MapViewer}from'@/utils/map3d/mapViewer';import{STATIC_URL}from'@/config';import{GLTFLoader}from'three/examples/jsm/loaders/GLTFLoader';constgetSpri......
  • 使用 Tailwind CSS 打造流星边框动画:提升网站视觉效果
    在现代网页设计中,良好的视觉效果不仅可以吸引用户的注意,还能提升网站的整体用户体验。今天我们要聊的就是如何使用TailwindCSS打造流星边框动画,为你的网站增添一抹炫丽的色彩。TailwindCSS是一个功能强大、灵活易用的CSS框架,帮助我们快速实现各种复杂的设计效果。而流星边......