关于开发CSS3弹性盒模型的方法之二

这篇文章主要为大家分享了css3弹性盒模型开发笔记,想要学好css3弹性盒模型的朋友不要错过这篇文章,可以参考一下

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

box-flex属性

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

box-flex:

立即学习“前端免费学习笔记(深入)”;

取值说明:

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

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

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

html代码:

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

        

        

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

            

        

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

    

登录后复制

CSS3代码:

/*这是一个三栏布局的页面,其中左侧栏目的宽度是固定的,而中间和右侧栏目的宽度是弹性的*/   body{       margin:0;       padding:0;       text-align:center;   }   h1,h2{margin:2px;}   #box{       margin:auto;       text-align:left;       width:1002px;       overflow:hidden;   }   /*定义box元素盒形显示,并设置子元素水平布置*/#box{       display:box;       display:-moz-box;       display:-webkit-box;       box-orient:horizontal;       -moz-box-orient:horizontal;       -webkit-box-orient:horizontal;     }   /*定义盒子左侧栏目的宽度为固定显示*/#box1{width:201px;}   #box2,#box3{       border:1px solid #CCC;       margin:2px;    }   /*定义盒子内中间栏目的宽度为盒子剩余空间的2/3*/#box2{       box-flex: 4;       -moz-box-flex: 4;       -webkit-box-flex: 4;   }   /*定义盒子内中间栏目的宽度为盒子剩余空间的1/3*/#box3{       box-flex:2;       -moz-box-flex:2;       -webkit-box-flex:2;    }   #box2 p,#box3 p{       display:inline;   }   

登录后复制

演示效果:

关于开发CSS3弹性盒模型的方法之二

弹性空间的实现和分配

  在默认情况下,子元素并不具有弹性,它会竟可能的宽,以便使其所包含的内容可见,并且不会有任何溢出。如果要改变它的尺寸,则可以使用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代码:

关于开发CSS3弹性盒模型的方法之二

        

关于开发CSS3弹性盒模型的方法之二

        

        

登录后复制

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

CSS3代码:

#box2{       box-flex: 2;       -moz-box-flex: 2;       -webkit-box-flex: 2;       background:#CCF;   }   #box3{       box-flex: 2;       -moz-box-flex: 2;       -webkit-box-flex: 2;       background:#FC0;   }

登录后复制

演示效果:

关于开发CSS3弹性盒模型的方法之二

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

CSS3代码:

#box2{       box-flex: 0.5;       -moz-box-flex: 0.5;       -webkit-box-flex: 0.5;       background:#CCF;   }   #box3{       box-flex: 2;       -moz-box-flex: 2;       -webkit-box-flex: 2;       background:#FC0;   }

登录后复制

演示效果:

关于开发CSS3弹性盒模型的方法之二

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

CSS3代码:

#box2{       box-flex: 0.5;       -moz-box-flex: 0.5;       -webkit-box-flex: 0.5;       background:#CCF;   }   #box3{       width:196px;       background:url(images/web3_03.gif) no-repeat;   }

登录后复制

演示效果:

关于开发CSS3弹性盒模型的方法之二

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

CSS代码:

#box2{       box-flex: 0;       -moz-box-flex: 0;       -webkit-box-flex: 0;       background:#CCF;   }   #box3{       width:196px;       background:url(images/web3_03.gif) no-repeat;   }

登录后复制

演示效果:

关于开发CSS3弹性盒模型的方法之二

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

关于开发CSS3弹性盒模型的方法之一

以上就是关于开发CSS3弹性盒模型的方法之二的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2896509.html

(0)
上一篇 2025年3月10日 23:12:54
下一篇 2025年3月10日 20:37:36

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 如何使用CSS3实现折角效果

    这篇文章主要为大家介绍了利用css3实现折角的效果,当鼠标移动到图片上的时候就会出现折角的效果,文中给出了实例代码更方便大家的理解和学习,下面大家来一起学习学习吧。 先来看看静态的效果图 实例代码 nbsp;html>        …

    2025年3月10日
    200
  • 利用CSS3绘制打火机动画火焰的效果

    这篇文章主要为大家详细介绍了纯css3绘制打火机动画火焰效果的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文实例为大家分享了纯CSS3绘制打火机动画火焰效果的具体代码,供大家参考,具体内容如下 主要涉及到了以下属性: an…

    2025年3月10日
    200
  • 关于css3中矩阵的使用方法

    这篇文章主要介绍了css3 矩阵的使用详解的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 css3 矩阵变化. 应用格式为: transform: matrix(a,b,c,d,e,f);登录后复制 …

    2025年3月10日
    200
  • 如何使用CSS3配合IE滤镜实现渐变和投影的效果

    这篇文章主要介绍了使用css3配合ie滤镜实现渐变和投影的效果的一些方法,尽管ie即将退出历史舞台,但也可以为edge浏览器的相关开发积累经验,需要的朋友可以参考下 线性渐变在CSS3和IE滤镜中的实现对于完美主义者来说,为了一个渐变而使用…

    2025年3月10日 编程技术
    200
  • 利用html和CSS3实现导航栏

    本篇文章给大家分享基于html和css3制作酷炫的导航栏,效果非常美观,需要的朋友可以从参考下  主要亮点:   1 ul 水平显示   2 li 去掉圆点   3 li中字体水平、竖直居中 立即学习“前端免费学习笔记(深入)”;   4 …

    2025年3月10日
    200
  • 使用CSS3实现模拟IOS滑动开关效果

    这篇文章主要为大家详细介绍了css3模拟ios滑动开关效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 前言 H5站点需要IOS滑动按钮的效果,想了想似乎CSS3能搞起,就折腾出来了…挺简单的..请看注释 效果 代码 立即…

    2025年3月10日
    200
  • 关于CSS3实现自定义Checkbox的特效

    这篇文章主要给大家介绍了利用css3实现自定义checkbox特效的相关资料,文中给出了完整的实例代码供大家参考学习,相信对大家学习自定义checkbox样式具有一定的参考价值,感兴趣的朋友们下面来一起看看吧。 前言 大家都知道CheckB…

    2025年3月10日
    200
  • 关于使用CSS3制作动画的方法

    这篇文章主要介绍了css3动画制作的简单示例,特别是像文中这样实现一个动态表情的情况是非常给力的~需要的朋友可以参考下 CSS3 大大强化了制作动画的能力,但是如果要做出图案比较复杂的动画,选择 GIF 依然是一个不错的选择。今天给大家介绍…

    2025年3月10日
    200
  • 如何使用CSS3的box-reflect来制作倒影效果

    以前要实现这种效果,我们只能乖乖的找设计去制作,然后在页面上插入一张图片,但是随着css3的出现,我们可以纯代码实现,如何实现呢?就是通过css3的box-reflect属性。下面这篇文章就给大家分享了用css3来制作倒影效果的方法,有需要…

    2025年3月10日 编程技术
    200
  • 关于CSS3中border-image属性的使用

    这篇文章主要介绍了详解css3中border-image的使用,是css3入门学习中的基础知识,需要的朋友可以参考下 最近在项目中用到了border-image,一直是只知其名,不知其用。 最终效果是这样的:且随着border宽度变化。下图…

    2025年3月10日
    200

发表回复

登录后才能评论