Rumah hujung hadapan web tutorial css 关于开发CSS3弹性盒模型的方法之二

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

Jun 20, 2018 pm 02:09 PM
css3 keanjalan model kotak

这篇文章主要为大家分享了CSS3弹性盒模型开发笔记,想要学好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代码:

&lt;body&gt;
&lt;h1&gt;&lt;img src=&quot;images/web3_13.gif&quot; /&gt;&lt;/h1&gt;
&lt;p id=&quot;box&quot;&gt;
    &lt;!--左侧栏目--&gt;
    &lt;p id=&quot;box1&quot;&gt;&lt;img src=&quot;images/web3_01.gif&quot; /&gt;&lt;/p&gt;
    &lt;!--中间栏目--&gt;
    &lt;p id=&quot;box2&quot;&gt;
        &lt;h2&gt;&lt;img src=&quot;images/web3_02.gif&quot; /&gt;&lt;/h2&gt;
        &lt;p&gt;&lt;img src=&quot;images/web3_04.gif&quot; /&gt;&lt;/p&gt;
        &lt;p&gt;&lt;img src=&quot;images/web3_05.gif&quot; /&gt;&lt;/p&gt;
        &lt;p&gt;&lt;img src=&quot;images/web3_06.gif&quot; /&gt;&lt;/p&gt;
        &lt;p&gt;&lt;img src=&quot;images/web3_07.gif&quot; /&gt;&lt;/p&gt;
    &lt;/p&gt;
    &lt;!--右侧栏目--&gt;
    &lt;p id=&quot;box3&quot;&gt;
        &lt;h2&gt;&lt;img src=&quot;images/web3_12.gif&quot; /&gt;&lt;/h2&gt;
        &lt;p&gt;&lt;img src=&quot;images/web3_08.gif&quot; /&gt;&lt;/p&gt;
        &lt;p&gt;&lt;img src=&quot;images/web3_09.gif&quot; /&gt;&lt;/p&gt;
        &lt;p&gt;&lt;img src=&quot;images/web3_10.gif&quot; /&gt;&lt;/p&gt;
        &lt;p&gt;&lt;img src=&quot;images/web3_11.gif&quot; /&gt;&lt;/p&gt;
    &lt;/p&gt;
&lt;/p&gt;
&lt;/body&gt;
Salin selepas log masuk

CSS3代码:

/*这是一个三栏布局的页面,其中左侧栏目的宽度是固定的,而中间和右侧栏目的宽度是弹性的*/
&lt;style&gt;   
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;   
}   
&lt;/style&gt;
Salin selepas log masuk

演示效果:

弹性空间的实现和分配

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

&lt;body&gt;
&lt;h1&gt;&lt;img src=&quot;images/web3_13.gif&quot; /&gt;&lt;/h1&gt;
&lt;p id=&quot;box&quot;&gt;
    &lt;!--左侧栏目--&gt;
    &lt;p id=&quot;box1&quot;&gt;&lt;img src=&quot;images/web3_01.gif&quot; /&gt;&lt;/p&gt;
    &lt;!--中间栏目--&gt;
    &lt;p id=&quot;box2&quot;&gt;&lt;/p&gt;
    &lt;!--右侧栏目--&gt;
    &lt;p id=&quot;box3&quot;&gt;&lt;/p&gt;
&lt;/p&gt;
&lt;/body&gt;
Salin selepas log masuk

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

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;   
}
Salin selepas log masuk

演示效果:

中栏占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;   
}
Salin selepas log masuk

演示效果:

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

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;   
}
Salin selepas log masuk

演示效果:

中栏失去弹性(当设置为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;   
}
Salin selepas log masuk

演示效果:

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

相关推荐:

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

Atas ialah kandungan terperinci 关于开发CSS3弹性盒模型的方法之二. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk mencapai kesan gelombang dengan CSS3 tulen? (contoh kod) Bagaimana untuk mencapai kesan gelombang dengan CSS3 tulen? (contoh kod) Jun 28, 2022 pm 01:39 PM

Bagaimana untuk mencapai kesan gelombang dengan CSS3 tulen? (contoh kod)

Gunakan CSS dengan mahir untuk merealisasikan pelbagai butang berbentuk pelik (dengan kod) Gunakan CSS dengan mahir untuk merealisasikan pelbagai butang berbentuk pelik (dengan kod) Jul 19, 2022 am 11:28 AM

Gunakan CSS dengan mahir untuk merealisasikan pelbagai butang berbentuk pelik (dengan kod)

Bagaimana untuk menyembunyikan elemen dalam css tanpa mengambil ruang Bagaimana untuk menyembunyikan elemen dalam css tanpa mengambil ruang Jun 01, 2022 pm 07:15 PM

Bagaimana untuk menyembunyikan elemen dalam css tanpa mengambil ruang

Bagaimana untuk melaksanakan sempadan renda dalam css3 Bagaimana untuk melaksanakan sempadan renda dalam css3 Sep 16, 2022 pm 07:11 PM

Bagaimana untuk melaksanakan sempadan renda dalam css3

Ternyata karusel teks dan karusel imej juga boleh direalisasikan menggunakan CSS tulen! Ternyata karusel teks dan karusel imej juga boleh direalisasikan menggunakan CSS tulen! Jun 10, 2022 pm 01:00 PM

Ternyata karusel teks dan karusel imej juga boleh direalisasikan menggunakan CSS tulen!

css3 apakah itu susun atur penyesuaian css3 apakah itu susun atur penyesuaian Jun 02, 2022 pm 12:05 PM

css3 apakah itu susun atur penyesuaian

Bagaimana untuk menetapkan kelajuan putaran animasi dalam css3 Bagaimana untuk menetapkan kelajuan putaran animasi dalam css3 Apr 28, 2022 pm 04:32 PM

Bagaimana untuk menetapkan kelajuan putaran animasi dalam css3

Konsep dan fungsi model kotak HTML Konsep dan fungsi model kotak HTML Feb 18, 2024 pm 09:49 PM

Konsep dan fungsi model kotak HTML

See all articles