博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CSS盒子模型
阅读量:7127 次
发布时间:2019-06-28

本文共 1107 字,大约阅读时间需要 3 分钟。

序言

CSS盒子模型算是CSS中最重要的一部分,在开发中遇到难以理解的现象,往往是因为对模型的理解不够。 盒子模型主要有标准模型和IE模型,本文主要讲述:

  • 标准模型基本概念
  • 标准模型与IE模型的区别
  • 边距重叠与BFC
  • 其他

标准模型基本概念

标准模型「默认:box-sizing: content-box」由四部分组成,从内到外依次是:

  • 内容区域「content」:可以放置元素的区域如文本,图像等,一般设置宽高度指的是这个内容的宽高;
  • 内边距区域「padding」:内容与边框之间的距离
  • 边框区域「border」:就是边框
  • 外边距区域「margin」:由外边边距限制,用空白区域扩展边框区域,来分开相邻的元素。

标准模型与IE模型的区别

标准模型指的是设置box-sizing为content-box的盒子模型,一般width,height 指的是content的宽高。 而IE模型指的是box-sizing为border-box的盒子模型。宽高的计算是content+padding+border;

边距重叠与BFC

外边重叠三种情况:

  • 相邻元素之间
  • 父元素与其第一个或最后一个字元素之间
  • 空的块级元素

BFC

BFC的定义:见MDN

BFC的作用:

  • 让浮动内容与周围内容等高 当浮动内容溢出容器的时候,创建容器的BFC,来包裹这个浮动。

  • 外边距蹦陷 当外边距被合并时,创建各自的BFC,来解决问题 父元素与第一个元素上边距合并,创建父元素与第一个元素的各自的BFC

其他

包含块的影响

当我们设置元素的一些属性,譬如:width、height、padding、margin、定位的偏移值「top,left」,常常受到起包含块的影响。

谁是你的包含块

  • position 属性为static,relative 包含块为最近祖先块元素。
  • position 属性为absolute,包含块为不是static的祖先元素,这跟定位差不多。
  • position 为 fixed,包含块就是 viewport,也就是整个屏幕大小

元素的width、padding、margin、定位的偏移值「top,left」百分比是根据包含块的宽度计算

如何画一个自适应宽高的正方形

div{    width: 100%;    padding-bottom: 100%;}复制代码

因为padding跟width的计算是根据包含块的宽度计算的,而height = content + padding 所以这样能画出一个正方形。

参考

转载于:https://juejin.im/post/5ce60f346fb9a07ef37640a3

你可能感兴趣的文章
redis 客户端工具
查看>>
Apache禁止用IP非法域名访问网站
查看>>
监控服务篇---zabbix安装部署步骤
查看>>
nagios 远程Mysql 监控 PHP图表
查看>>
PingingLab传世经典系列《CCNA完全配置宝典》-3.13 DHCP基本配置
查看>>
新的开始
查看>>
fedora 20 上的hadoop 2.2.0 x64 编译过程
查看>>
找创业伙伴,比找老婆还难【转载】
查看>>
yarn上手体验
查看>>
iOS 图片和音频的防盗链的应用
查看>>
Exchange Server 2010高可用性配置
查看>>
Linux 运维工程师:30 道面试题整理
查看>>
负载均衡之基于DNS负载
查看>>
Hadoop集群(第8期)_HDFS初探之旅
查看>>
Centos6.8 64 位 Discuz 运行环境
查看>>
我的友情链接
查看>>
社交系统ThinkSNS+预售活动结束倒计时
查看>>
克隆虚拟机
查看>>
资讯直播,会是下一个新风口吗
查看>>
企业邮箱自建战略优势大盘点
查看>>