栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

CSS3弹性盒模型开发笔记(二)

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

本文为大家继续分享CSS3弹性盒模型开发笔记第二篇,之前一篇以及为大家引入了CSS3弹性盒模型的相关介绍,点击查看:CSS3弹性盒模型开发笔记(一)

box-flex属性

box-flex属性能够灵活地控制子元素在盒子中的显示空间。注意,显示空间包括子元素的宽度和高度,而不只是子元素所在栏目的宽度,也可以说是子元素在盒子中所占的面积。该属性在弹性布局中非常重要,它解决了传统设计中习惯使用百分比定义弹性布局的弊端。box-flex属性的基本语法:

box-flex:

取值说明:

属性值是一个整数或者小数。当盒子中包含多个定义了box-flex属性的子元素时,浏览器将会把这些子元素的box-flex属性值相加,然后根据他们各自的值占总值的比例来分配盒子剩余的空间。注意,box-flex属性只有在盒子拥有的确定的空间大小之后才能正确解析。在设计中,较稳妥的做法是为了盒子定义具体的width或height属性值。

实战体验:自适应栏目宽度设计

在传统的网页设计中,如果要把一个栏目分成三栏,比较简单的做法是把三个子元素的宽度都设置为33.3%。这种做法无法把父元素的宽度完全填充,当父元素的宽度足够大的时候,用户会看到未填充的空白区域。但是,如果为子元素设置了固定宽度值,弹性布局会变得更为复杂。如果使用box-flex属性,这个问题就会迎刃而解。

html代码:

XML/HTML Code复制内容到剪贴板
  1.   


  2.   
  3.   
  4.       
  5.     

  
  •       
  •       
  •         



      
  •         


      
  •         


      
  •         


      
  •         


      
  •     
  •   
  •       
  •       
  •         



      
  •         


      
  •         


      
  •         


      
  •         


      
  •     
  •   
  •   
  •   
  • CSS3代码:

    CSS Code复制内容到剪贴板
    1.   
    2.   
    3. body{   
    4.     margin:0;   
    5.     padding:0;   
    6.     text-align:center;   
    7. }   
    8. h1,h2{margin:2px;}   
    9. #box{   
    10.     margin:auto;   
    11.     text-align:left;   
    12.     width:1002px;   
    13.     overflow:hidden;   
    14. }   
    15.   
    16. #box{   
    17.     display:box;   
    18.     display:-moz-box;   
    19.     display:-webkit-box;   
    20.     box-orient:horizontal;   
    21.     -moz-box-orient:horizontal;   
    22.     -webkit-box-orient:horizontal;     
    23. }   
    24.   
    25. #box1{width:201px;}   
    26. #box2,#box3{   
    27.     border:1px solid #CCC;   
    28.     margin:2px;    
    29. }   
    30.   
    31. #box2{   
    32.     box-flex: 4;   
    33.     -moz-box-flex: 4;   
    34.     -webkit-box-flex: 4;   
    35. }   
    36.   
    37. #box3{   
    38.     box-flex:2;   
    39.     -moz-box-flex:2;   
    40.     -webkit-box-flex:2;    
    41. }   
    42. #box2 div,#box3 div{   
    43.     display:inline;   
    44. }   
    45.   
    46.   

    演示效果:

    弹性空间的实现和分配

      在默认情况下,子元素并不具有弹性,它会竟可能的宽,以便使其所包含的内容可见,并且不会有任何溢出。如果要改变它的尺寸,则可以使用width和height属性来实现,当然也可以使用min-height,min-width,max-height,max-width等属性来限制尺寸。

      当box-flex属性至少大于0时,它会变得富有弹性。当子元素具有弹性时,可以通过下面的方式来改变它的尺寸:

    1、使用width,height,min-height,min-width,max-height,max-width等属性来定义尺寸。

    2、使用盒子的尺寸来限制子元素的弹性尺寸。

    3、借助盒子富余所有空间来限制元素的弹性尺寸。

      如果子元素没有声明大小,那么其尺寸将完全取决于盒子的大小,即子元素的大小等于盒子的大小乘以它的box-flex属性值在所有子元素的box-flex属性值总和中的百分比。使用公式表示如下:

    子元素的尺寸=盒子的尺寸*子元素的box-flex属性值/所有子元素的box-flex属性值的和

    如果一个或多个子元素声明了具体的尺寸,那么其大小将计入其中,余下的弹性盒子将按照上面的原则分享剩余的可利用空间。

    由于受内部图片大小的支撑,导致子元素的空间总是大于盒子的 富余空间,这时将出现解析异常。

    box-flex属性对子元素的布局影响

    HTML代码:

    XML/HTML Code复制内容到剪贴板
    1.   


    2.   
    3.   
    4.       
    5.     

        
    6.       
    7.       
    8.          
    9.               
    10.   
    11.   
    12.   

    中间和右侧各占一半剩余的空间

    CSS3代码:

    CSS Code复制内容到剪贴板
    1. #box2{   
    2.     box-flex: 2;   
    3.     -moz-box-flex: 2;   
    4.     -webkit-box-flex: 2;   
    5.     background:#CCF;   
    6. }   
    7. #box3{   
    8.     box-flex: 2;   
    9.     -moz-box-flex: 2;   
    10.     -webkit-box-flex: 2;   
    11.     background:#FC0;   
    12. }   
    13.   

    演示效果:

    中栏占1/5的空余空间,右栏占4/5空余的空间

    CSS3代码:

    CSS Code复制内容到剪贴板
    1. #box2{   
    2.     box-flex: 0.5;   
    3.     -moz-box-flex: 0.5;   
    4.     -webkit-box-flex: 0.5;   
    5.     background:#CCF;   
    6. }   
    7. #box3{   
    8.     box-flex: 2;   
    9.     -moz-box-flex: 2;   
    10.     -webkit-box-flex: 2;   
    11.     background:#FC0;   
    12. }   
    13.   

    演示效果:

    中间弹性显示,占据所有空余空间,右栏固定大

    CSS3代码:

    CSS Code复制内容到剪贴板
    1. #box2{   
    2.     box-flex: 0.5;   
    3.     -moz-box-flex: 0.5;   
    4.     -webkit-box-flex: 0.5;   
    5.     background:#CCF;   
    6. }   
    7. #box3{   
    8.     width:196px;   
    9.     background:url(images/web3_03.gif) no-repeat;   
    10. }   
    11.   

    演示效果:

    中栏失去弹性(当设置为0或者复制时),收缩显示为一条线,右栏自动左移

    CSS代码:

    CSS Code复制内容到剪贴板
    1. #box2{   
    2.     box-flex: 0;   
    3.     -moz-box-flex: 0;   
    4.     -webkit-box-flex: 0;   
    5.     background:#CCF;   
    6. }   
    7. #box3{   
    8.     width:196px;   
    9.     background:url(images/web3_03.gif) no-repeat;   
    10. }   
    11.   

    演示效果:

    以上就是本文的全部内容,希望对大家学习CSS3弹性盒模型有所帮助。

    转载请注明:文章转载自 www.mshxw.com
    本文地址:https://www.mshxw.com/it/215984.html

    CSS教程相关栏目本月热门文章

    我们一直用心在做
    关于我们 文章归档 网站地图 联系我们

    版权所有 (c)2021-2022 MSHXW.COM

    ICP备案号:晋ICP备2021003244-6号