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 相关文章推荐
利用纯CSS3实现文字向右循环闪过效果实例(可用于移动端)
Jun 15 HTML / CSS
css3 线性渐变和径向渐变示例附图
Apr 08 HTML / CSS
css3 transform属性详解
Sep 30 HTML / CSS
使用CSS3来代替JS实现交互
Aug 10 HTML / CSS
使用Canvas操作像素的方法
Jun 14 HTML / CSS
突袭HTML5之Javascript API扩展2—地理信息服务及地理位置API学习
Jan 31 HTML / CSS
html标签之Object和EMBED标签详解
Jul 04 HTML / CSS
HTML5的download属性详细介绍和使用实例
Apr 23 HTML / CSS
基于HTML5的WebGL实现json和echarts图表展现在同一个界面
Oct 26 HTML / CSS
详解如何使用rem或viewport进行移动端适配
Aug 14 HTML / CSS
Amaze UI 文件选择域的示例代码
Aug 26 HTML / CSS
深入理解CSS 中 transform matrix矩阵变换问题
Aug 30 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
如何在PHP中使用Oracle数据库(5)
2006/10/09 PHP
PHP Error与Logging函数的深入理解
2013/06/03 PHP
微信自定义菜单的处理开发示例
2015/04/16 PHP
PHP设计模式概论【概念、分类、原则等】
2020/05/01 PHP
新发现一个骗链接的方法(js读取cookies)
2012/01/11 Javascript
jquery实现隐藏与显示动画效果/输入框字符动态递减/导航按钮切换
2013/07/01 Javascript
Jquery实现的一种常用高亮效果示例代码
2014/01/28 Javascript
做web开发 先学JavaScript
2014/12/12 Javascript
jQuery实现非常实用漂亮的select下拉菜单选择效果
2015/11/06 Javascript
浅谈JavaScript 数据属性和访问器属性
2016/09/01 Javascript
Angular 常用指令实例总结整理
2016/12/13 Javascript
日期时间范围选择插件:daterangepicker使用总结(必看篇)
2017/09/14 Javascript
使用ef6创建oracle数据库的实体模型遇到的问题及解决方案
2017/11/09 Javascript
解决koa2 ctx.render is not a function报错问题
2018/08/07 Javascript
angular5 子组件监听父组件传入值的变化方法
2018/09/30 Javascript
vue路由--网站导航功能详解
2019/03/29 Javascript
nodejs语言实现验证码生成功能的示例代码
2019/10/13 NodeJs
javascript实现简单搜索功能
2020/03/26 Javascript
vue项目或网页上实现文字转换成语音播放功能
2020/06/09 Javascript
Python实现图像几何变换
2015/07/06 Python
Python3.5局部变量与全局变量作用域实例分析
2019/04/30 Python
Python2.x与3​​.x版本有哪些区别
2020/07/09 Python
详解CSS3中字体平滑处理和抗锯齿渲染
2017/03/29 HTML / CSS
Steve Madden官网:美国鞋类品牌
2017/01/29 全球购物
德国高尔夫商店:Golfshop.de
2019/06/22 全球购物
意大利时尚精品店:Nugnes 1920
2020/02/10 全球购物
JACK & JONES荷兰官网:男士服装和鞋子
2021/03/07 全球购物
Happy Plugs官网:瑞典无线耳机品牌
2020/07/16 全球购物
名词解释WEB SERVICE,SOAP,UDDI,WSDL,JAXP,JAXM;JSWDL开发包的介绍。
2012/10/27 面试题
如何实现一个自定义类的序列化
2012/05/22 面试题
测绘工程专业个人自我评价
2013/12/01 职场文书
洗煤厂厂长岗位职责
2014/01/03 职场文书
新教师工作感言
2014/02/16 职场文书
PHP 技巧 * SVG 保存为图片(分享图生成)
2021/04/02 PHP
JS数组去重详情
2021/11/07 Javascript
Vue3实现简易音乐播放器组件
2022/08/14 Vue.js