博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CSS3:box-sizing:不再为盒子模型而烦恼
阅读量:4985 次
发布时间:2019-06-12

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

题外话:

W3C奉行的标准,就是content-box,就是须要计算边框,填充还有内容的;可是就我个人而言,

比較喜欢的是传统IE6时候的怪异模式,不用考虑容器是否会被撑开(打乱布局);


盒子模型差异

盒子大小计算原理

W3C标准盒子 = (边框 + 填充 + 内容块大小) ,牵一发而动全身;

传统IE6盒子 = 总体宽高(边框,填充和随盒子大小而调整变化)

若是计算占用位置,两种盒子都要算上margin(边距)

简言之,W3C标准盒子是须要相加各种大小得到总体的宽高,而传统的IE6是从总体减去内在元素大小而达到调整效果


CSS3:box-sizing

box-sizing : content-box | border-box | inherit;,针对火狐的还有个padding-box,差点儿不用啊!!!

  • content-box : 标准的W3C盒子模型
  • border-box: 传统IE6的盒子模型
  • padding-box: 眼下仅仅对火狐生效,也是减去适应..可是从padding開始

验证及效果

代码

简易代码,三个盒子

    
box-sizing
我是盒子内部的内容啊!!
我是盒子内部的内容啊!!
我是盒子内部的内容啊!!

效果图

  • 标准模型的盒子大小(280X280) = 200 +10*2 + 30*2 — 相加效果

Demo1

  • 传统IE6盒子大小(200X200) = 120 + 10 * 2 + 30*2 — 减去效果

Demo2

  • 针对火狐的padding-box盒子大小(260X260) = 180 + 10*2 + 30*2 –减去效果从padding開始

Demo3

总结

  1. 这个属性支持IE8+,其它浏览器基本都支持了(应该非常少人用非常老的FF,CHROME这些吧)
  2. 感觉border-box非常适合用来排版布局,由于不用操心内距填充这些导致盒子大于包裹层大小,导致换行,或者其它乱七八糟的问题
  3. 标准盒子也有他的优点,能够针对性的控制内容块的大小..非常仔细的做出调整,就是须要计算比較麻烦点

转载于:https://www.cnblogs.com/blfbuaa/p/7110963.html

你可能感兴趣的文章
php_常用操作_读取文件_数据库操作
查看>>
Linux中GCC源码编译安装
查看>>
equals与==关于Object覆盖和重载问题
查看>>
KVO
查看>>
js基础教程四之无缝滚动
查看>>
关于C51 keil使用中.c文件的链接心得
查看>>
Ios 弹框 MJPopup,KxMenu
查看>>
ssh框架添加时添加不到数据库问题
查看>>
解决AR中Receivable Activities 运行不了的问题
查看>>
SQL SERVER 如何处理带字母的自增列--【叶子】
查看>>
使用DocFX生成文档
查看>>
AssemblyInfo.cs文件的作用
查看>>
android之PackageManager简单介绍
查看>>
GitLab备份与恢复
查看>>
20155307《网络对抗》免杀原理与实践
查看>>
《Android开发卷——自定义日期选择器(三)》
查看>>
游里工夫独造微一一小平邦彦传
查看>>
HTML5 JSON ( tuple => Object => JSON => Object=> Elements_of_tuple )
查看>>
layui中的html怎样接收后台的值,layui框架与SSM前后台交互的方法
查看>>
Skulpt在线模拟运行Python工具
查看>>