CSS3盒模型之box-sizing

这些天在做一个手机端的页面,遇到了一些问题!首当其冲的就是盒子的溢出问题!大家都知道,手机的尺寸各异,各种型号的手机多得能闪瞎你们的眼睛,为了能 让这些设置更好的浏览我们的页面,我们已经不能固定页面的大小了。所以很多时候我们对于大小的设置都需要使用百分比,嗯,试试看吧!

对于一个导航,我们初始是想这样:

代码如下:

css:

nav{width100%;background#001125;overflowhidden}

nav a{displayblock;floatleft;width20%;height60px;color#FFF;text-aligncenter;font16px/60px Microsoft YaHei;background#0A92CD}

nav a.p1{background: orange}

nav a.p2{backgroundpurple}

nav a.p3{backgroundgreen}

nav a.p4{backgroundblue}

nav a.p5{backgroundgray}

效果如下:

嗯,看起来还是不错的!

但是,很显然,在实际开发过程中总是存在各种“但是”(比如,产品经理对设计师说:这样不好看,我们要背景一致,用竖线把它们分隔开来...由于是乎,设计师就把方案改了~ 结果,前端工程师就屁颠屁颠的改代码)

css:

nav{width100%;background#001125;overflowhidden}

nav a{displayblock;floatleft;width20%;height60px;border-right:1px solid #001125;color#FFF;text-aligncenter;font16px/60px Microsoft YaHei;background#0A92CD}

nav a:last-child{border-rightnone}

一段时间后...终于改好了!来看一下效果吧~

“帮助”你为什么没有跟你们兄弟站在一条战线上?

对啊,为什么呢?我翻资料,查找原因...我查...

原来:现代浏览器对于盒模型的解析引起的问题,它们不会将border和padding包含在width之内,所以,这里各自20%的宽度是不包括border-right:1px的,现在元素中20%*5+4px(4个border-right:1px,最后一个被nav a:last-child{border-right: none}去除了)当然就超过了父容器100%的宽度了,所以第一排已经容不下“帮助”了,它不得不孤独的自成一排。

那么,有什么办法可以让它们兄弟重新“团聚”呢?那就是我们今天的主角:box-sizing!只需要,在为所有兄弟设置box-sizing:border-box,就可以让它们合家团圆了!

css:

nav{width100%;background#001125;overflowhidden}

nav a{displayblock;floatleft;width20%;height60px;border-right:1px solid #001125;color#FFF;text-aligncenter;font16px/60px Microsoft YaHei;background#0A92CD;box-sizing:border-box}

nav a:last-child{border-rightnone}

来看看是不是真的实现了呢?

那是必须的!

IE6以前的版本中,对盒模型的解析其实不需要设置border-box就已经是将border与padding包含在了width之内。所以,IE6以前版本的浏览器,在此前的dome中可能就已经没问题了。在我们开发的过程中会发现,有时候,如果对页面中的大区域进行设置时,将border、padding计算到width和height之内,反而更灵活。但W3C的 CSS2.1规范却规定了他们并不能被包含其中。所以才出现了刚才那样的问题。不过幸亏到了css3中引入了这个box-sizing的新属性,它具有 “content-box”和 “border-box”两个值。

box-sizing:conten-box就是遵从之前CSS2.1的W3C标准,当它定义width和height时,宽度不包括border和padding。

box-sizing:border-box时便是能完美解决问题的包含其中的设置了!

时间: 2024-10-16 08:11:43

CSS3盒模型之box-sizing的相关文章

CSS3盒模型display:box;box-flex:3;

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width"> <title>盒模型display:box;</title> </head> <body> <article class=&q

CSS3盒模型display:box详解

display:box;box-flex是css3新添加的盒子模型属性,它的出现可以解决我们通过N多结构.css实现的布局方式.经典的一个布局应用就是布局的垂直等高.水平均分.按比例划分.目前box-flex属性还没有得到firefox.Opera.chrome浏览器的完全支持,但可以使用它们的私有属性定义firefox(-moz-).opera(-o-).chrome/safari(-webkit-).一.box-flex属性box-flex主要让子容器针对父容器的宽度按一定规则进行划分htm

[转]CSS3盒模型display:box详解

时间:2014-02-25来源:网络作者:未知编辑:RGB display:box;box-flex是css3新添加的盒子模型属性,它的出现可以解决我们通过N多结构.css实现的布局方式.经典的一个布局应用就是布局的垂直等高.水平均分.按比例划分. 目前box-flex属性还没有得到firefox.Opera.chrome浏览器的完全支持,但可以使用它们的私有属性定义firefox(-moz-).opera(-o-).chrome/safari(-webkit-). 一.box-flex属性 b

CSS盒模型(Box Model)

阅读目录 1. 什么是CSS盒模型 2. IE盒模型和W3C盒模型 3. CSS3属性box-sizing 4. 关于盒模型的使用 在最初接触CSS的时候,对于CSS盒模型的不了解,撞了很多次的南墙呀.盒模型是网页布局的基础,它制定了元素如何在页面中显示,如果足够地掌握,那使用CSS布局那将会容易得多. 1. 什么是CSS盒模型 盒模型,顾名思义,就是一个盒子.生活中的盒子,有长宽高,盒子本身也有厚度,可以用来装东西.页面上的盒模型我们可以理解为,从盒子顶部俯视所得的一个平面图,盒子里装的东西,

CSS3盒模型温故

CSS有一种基础设计模式叫盒模型,定义了Web页面中的元素是如何看做盒子来解析的.每一个盒子有不同的展示界面,下面就来介绍盒模型,主要有一下几种盒模型:inline.inline-block.block.table.absolute position.float.浏览器把每个元素看做一个盒模型,每个盒模型是由以下几个属性组合所决定的:display.position.float.width.height.margin.paddinghe border等,不同类型的盒模型会产生不同的布局 什么是盒

css3 盒模型

0,前言 在css2.1 之前,我们都熟知的两种盒模型,一种是w3c标准盒模型,另外一种是怪异模式下的盒模型.在css3之前我们一直使用的是标准盒模型,但是标准盒模型的宽度总是需要小心的去使用,稍有不甚,有会带来混乱.css3让我们之前了解的怪异模式能够很好的在页面中使用,下面来了解下上面提到的w3c标准盒模型和怪异模式下的盒模型. div { width: 200px; height: 100px; padding: 20px; border:30px solid blue; margin:

CSS3总结四:盒模型(box)

盒模型:标准盒模型.混杂盒模型 什么时候会触发混杂模式? 为什么要混杂模式渲染规则盒模型? box-sizing:content-box.border-box 关于盒模型的一些其他样式和属性值 一.盒模型:标准渲染规则盒模型.混杂模式渲染规则盒模型 标准渲染模式盒模型的渲染规则:DOM.width = border-left-width + padding-left + width(content-width) + padding-right + border-right-width;(dom.

CSS弹性盒模型(flex box)

本文介绍的是 CSS3 规范中引入的新布局模型:弹性盒模型(flex box).随着响应式用户界面的流行,Web 应用一般都要求适配不同的设备尺寸和浏览器分辨率. 浏览器支持: 弹性盒布局的容器(flex container)指的是采用了弹性盒布局的 DOM 元素,而弹性盒布局的条目(flex item)指的是容器中包含的子 DOM 元素.图中的最外围的边框表示的是容器,而编号 1 和 2 的边框表示的是容器中的条目. 主轴并不固定为水平方向的 X 轴,交叉轴也不固定为垂直方向的 Y 轴.在使用

css3盒模型

css2.1盒模型: 当你定义盒子的宽高后:如果添加padding和border值后盒子的宽高会被撑大 盒子的高度=定义的高度+(padding-top + padding-bottom)+(border-top + border-bottom); 盒子的宽度=定义的宽度+(padding-left+ padding-right)+(border-left+ border-right); css3.0盒模型: 当你定义盒子高度后:如果添加padding和border值后盒子大小不会改变,他会向内