CSS3 box-sizing属性


Posted in HTML / CSS onApril 17, 2009

说到 IE 的 bug,一个臭名昭著的例子是它对于“盒模型”的错误解释:在 IE5.x 以及 Quirks 模式的 IE6/7 中,将 border 与 padding 都包含在 width 之内。这为前端工程师的工作平添了不少麻烦,几户每个需要定义尺寸的 box 都要思量一下:是否触发了“盒模型 bug”?

同时,由于另一撮浏览器对标准的遵从,我们在精确定义一个在有限空间内显示的 box 时,也需要计算一下:留给它的空间只有那么大,刨去 border 和 padding,我们该把它的 width 写成多少呢?

这种情况在 CSS3 时代有了改善,得益于这个叫做 box-sizing 的属性,它具有“content-box”和“border-box”两个值。

  • 定义 box-sizing: content-box; 时,浏览器对盒模型的解释遵从我们之前认识到的 W3C 标准;
  • 定义 box-sizing: border-box; 时,浏览器对盒模型的解释与 IE6 相同;

CSS3 box-sizing属性

为什么说这个属性“迟来”呢?IE 对于盒模型的解释固然不符合 W3C 的规范,但是也有它的好处:无论如何改动 border 与 padding 的值,都不会导致 box 总尺寸发生变化,也就不会打乱页面整体布局。而在 Firefox 等现代浏览器下,如果我们要改变一下 padding 的值,就不得不重新计算 box 的 width。现在 IE6 寿终正寝,这个 CSS 属性未免有些姗姗来迟。

试用这个新属性,Firefox 请使用 -moz-box-sizing,Safari / WebKit 请使用 -webkit-box-sizing,Opera 直接用 box-sizing 即可。

HTML / CSS 相关文章推荐
一款利用html5和css3实现的3D立方体旋转效果教程
Apr 26 HTML / CSS
css3实现背景颜色渐变让图片不再是唯一的实现方式
Dec 18 HTML / CSS
css3实现顶部社会化分享按钮示例
May 06 HTML / CSS
使用CSS3制作一个简单的Chrome模拟器
Jul 15 HTML / CSS
用CSS3实现无限循环的无缝滚动的示例代码
Nov 01 HTML / CSS
详解css position 5种不同的值的用法
Jul 30 HTML / CSS
html5仿支付宝密码框的实现代码
Sep 06 HTML / CSS
如何使用amaze ui的分页样式封装一个通用的JS分页控件
Aug 21 HTML / CSS
详解HTML5中CSS外观属性
Sep 10 HTML / CSS
HTML5 body设置全屏背景图片的示例代码
Dec 08 HTML / CSS
六种css3实现的边框过渡效果
Apr 22 HTML / CSS
如何解决flex文本溢出问题小结
Jul 15 HTML / CSS
CSS3伪类选择器:nth-child()
Apr 02 #HTML / CSS
CSS3教程:新增加的结构伪类
Apr 02 #HTML / CSS
CSS3五个技巧给你的网站带来出色的效果
Apr 02 #HTML / CSS
CSS3教程:边框属性border的极致应用
Apr 02 #HTML / CSS
CSS3中的5个有趣的新技术
Apr 02 #HTML / CSS
介绍CSS3使用技巧5个
Apr 02 #HTML / CSS
CSS3教程(1):什么是CSS3
Apr 02 #HTML / CSS
You might like
PHP4实际应用经验篇(8)
2006/10/09 PHP
YII中assets的使用示例
2014/07/31 PHP
PHP CURL使用详解
2019/03/21 PHP
Alliance vs Liquid BO3 第三场2.13
2021/03/10 DOTA
jQuery 性能优化指南 (1)
2009/05/21 Javascript
原生js实现淘宝首页点击按钮缓慢回到顶部效果
2014/04/06 Javascript
JQuery 使用attr方法实现下拉列表选中
2014/10/13 Javascript
谈谈我对JavaScript DOM事件的理解
2015/12/18 Javascript
使用Web Uploader实现多文件上传
2016/06/08 Javascript
js无提示关闭浏览器窗口的两种方法分析
2016/11/06 Javascript
JS查找英文文章中出现频率最高的单词
2017/03/20 Javascript
原生js实现移动端触摸轮播的示例代码
2017/12/22 Javascript
优雅的在React项目中使用Redux的方法
2018/11/10 Javascript
在vue中阻止浏览器后退的实例
2019/11/06 Javascript
vue 根据选择的月份动态展示日期对应的星期几
2021/02/06 Vue.js
[03:40]DOTA2抗疫特别篇《英雄年代》
2020/02/28 DOTA
编写Python脚本使得web页面上的代码高亮显示
2015/04/24 Python
Python设计模式之观察者模式简单示例
2018/01/10 Python
tensorflow 1.0用CNN进行图像分类
2018/04/15 Python
python 递归深度优先搜索与广度优先搜索算法模拟实现
2018/10/22 Python
Python 读取 YUV(NV12) 视频文件实例
2019/12/09 Python
keras tensorflow 实现在python下多进程运行
2020/02/06 Python
Clarins娇韵诗美国官网:法国天然护肤品牌
2016/09/26 全球购物
美国校园市场:OCM
2017/06/08 全球购物
西班牙家用电器和电子产品购物网站:Mi Electro
2019/02/25 全球购物
Crocs波兰官方商店:女鞋、男鞋、童鞋、洞洞鞋
2019/10/08 全球购物
企业治理工作自我评价
2013/09/26 职场文书
后勤岗位职责
2013/11/26 职场文书
集体备课反思
2014/02/12 职场文书
彩色的非洲教学反思
2014/02/18 职场文书
医药营销个人求职信
2014/04/12 职场文书
《月亮湾》教学反思
2014/04/14 职场文书
《他得的红圈圈最多》教学反思
2014/04/24 职场文书
个人廉政承诺书
2015/04/28 职场文书
sql server 累计求和实现代码
2022/02/28 SQL Server
Python获取指定日期是"星期几"的6种方法
2022/03/13 Python