CSS3弹性盒模型开发笔记(二)弹性盒模型开发笔记(二)
本文为大家继续分享CSS3弹性盒模型开发笔记第二篇,之前一篇以及为大家引入了CSS3弹性盒模型的相关介绍,点击查
看:CSS3弹性盒模型开发笔记(一)
box-flex属性属性
box-flex属性能够灵活地控制子元素在盒子中的显示空间。注意,显示空间包括子元素的宽度和高度,而不只是子元素所在栏
目的宽度,也可以说是子元素在盒子中所占的面积。该属性在弹性布局中非常重要,它解决了传统设计中习惯使用百分比定义
弹性布局的弊端。box-flex属性的基本语法:
box-flex:<number>
取值说明:
<number>属性值是一个整数或者小数。当盒子中包含多个定义了box-flex属性的子元素时,浏览器将会把这些子元素的box-
flex属性值相加,然后根据他们各自的值占总值的比例来分配盒子剩余的空间。注意,box-flex属性只有在盒子拥有的确定的
空间大小之后才能正确解析。在设计中,较稳妥的做法是为了盒子定义具体的width或height属性值。
实战体验:自适应栏目宽度设计实战体验:自适应栏目宽度设计
在传统的网页设计中,如果要把一个栏目分成三栏,比较简单的做法是把三个子元素的宽度都设置为33.3%。这种做法无法把
父元素的宽度完全填充,当父元素的宽度足够大的时候,用户会看到未填充的空白区域。但是,如果为子元素设置了固定宽度
值,弹性布局会变得更为复杂。如果使用box-flex属性,这个问题就会迎刃而解。
html代码:
XML/HTML Code复制内容到剪贴板
<body>
<h1><img src="images/web3_13.gif" /></h1>
<div id="box">
<!–左侧栏目–>
<div id="box1"><img src="images/web3_01.gif" /></div>
<!–中间栏目–>
<div id="box2">
<h2><img src="images/web3_02.gif" /></h2>
<div><img src="images/web3_04.gif" /></div>
<div><img src="images/web3_05.gif" /></div>
<div><img src="images/web3_06.gif" /></div>
<div><img src="images/web3_07.gif" /></div>
</div>
<!–右侧栏目–>
<div id="box3">
<h2><img src="images/web3_12.gif" /></h2>
<div><img src="images/web3_08.gif" /></div>
<div><img src="images/web3_09.gif" /></div>
<div><img src="images/web3_10.gif" /></div>
<div><img src="images/web3_11.gif" /></div>
</div>
</div>
</body>
CSS3代码:
CSS Code复制内容到剪贴板
/*这是一个三栏布局的页面,其中左侧栏目的宽度是固定的,而中间和右侧栏目的宽度是弹性的*/
<style>
body{
margin:0;
padding:0;
text-align:center;
}
h1,h2{margin:2px;}
#box{
margin:auto;
text-align:left;
width:1002px;