zoukankan      html  css  js  c++  java
  • 玩转CSS3(一)----CSS3实现页面布局

    版权声明:本文为博主原创文章,未经博主同意不得转载。

    https://blog.csdn.net/u012116457/article/details/28710173

    请珍惜小编劳动成果,该文章为小编原创,转载请注明出处。

    摘要:

        CSS3相对CSS2添加了一些新的布局方式:多栏布局和盒子布局。在这篇文章中。将对CSS2的布局进行简单的回顾,并总结CSS3的布局方式。

    DIV+CSS事实上是错误的叫法

         关于当前的页面布局。非常多人都习惯于叫做DIV+CSS,事实上这是一种错误的叫法。标准叫法应该叫做XHTML+CSS.
    这是为什么呢?传统的页面布局採用的是Table布局,即Table+CSS,后来出现了使用DIV的布局方式,所以人们就把它叫做DIV+CSS,并且有些人觉得用DIV+CSS制作的页面才是标准页面。事实上这句话是比較狭隘的。


    那什么是标准页面呢?WEB标准由结构,表现和行为三部分组成。当中结构话标准语言是XHTML和XML,表现化标准语言是CSS。由于XML比較复杂。大多数浏览器都没有全然支持。故不使用XML来实现页面布局,所以标准的页面布局应该是符合WEB标准的页面布局,即XHTML+CSS。
    而XHTML中不仅仅仅仅有DIV标签,还有a,p,ul,li,dl,dt等等标签,所以即使不使用DIV标签,制作的页面也是标准页面,XHTML的各个标签都有其功能,并非说仅仅能用DIV去实现页面布局(在一本书上有怎么一句话:假设满屏都是DIV,那也算不上标准页面了)
    所以说。以后我们要尽可能的说XHTML+CSS。而不是DIV+CSS.


    CSS2时代的布局方式

          简单点说,CSS2时代是使用float的浮动属性来实现布局的。

    layout.css

    /* CSS Document */
    
    /*基本信息*/
    body{
    margin:0px;  /*外边距*/
    text-align:center; /*文字居中对齐*/
    background:#E1D0BB;  /*背景色*/
    }
    /*页面层容器*/
    #container{     
    80%;
    height:100%;
    margin-left:10%;
    margin-right:10%;
    background:#ABE0F1;
    }
    /*头部*/
    #header{
    100%;
    height:15%;
    margin:0px;
    background:#FF0000;
    }
    
    #logo{
    float:left;    /*浮动属性,居左对齐,使其能够在同一行显示*/
    60%;
    height:80%;
    margin:0px;
    background:#E18CDD;
    clear:left;     /*取消左側浮动*/
    }
    #banner{
    float:right;   /*浮动属性,居右对齐。使其能够在同一行显示*/
    38%;
    height:80%;
    margin:0px;
    background:#8376D8;
    clear:right;    /*取消右側浮动*/
    }
    #menu{
    100%;
    height:5%;
    margin:0px;
    background:#00FF00;
    }
    #pageBody{
    100%;
    height:70%;
    margin:0px;
    background:#00FFFF;
    
    }
    #footer{
    100%;
    height:10%;
    margin:0px;
    background:#FFFF00;
    }
    
    
    
    

    layout.html

    <!DOCTYPE>
    <html>
    <head>
    <meta charset="utf-8">
    <title>布局</title>
    <link href="style/layout.css" rel="stylesheet" type="text/css" />
    </head>
    
    <body>
    <div id="container">
       <div id="header">
           <div id="logo">
    	     logo
    	   </div>
    	   <div id="banner">
    	   banner
    	   </div>
    	   container
       </div>
       <div id="menu">
       menu
       </div>
       <div id="pageBody">
    
       </div>
       <div id="footer">
       footer
       </div>
    </div>
    </body>
    </html>
    



    可是。使用float实现布局会有一些缺点,由于各个div是相互独立的。所以在一个div中添加一些内容后会使得无法对齐。CSS3提供了多栏布局和盒子布局来弥补这样的缺点。

    多栏布局

    layout.css
    /* CSS Document */
    
    /*基本信息*/
    body{
    margin:0px;  /*外边距*/
    text-align:center; /*文字居中对齐*/
    background:#E1D0BB;  /*背景色*/
    }
    /*页面层容器*/
    #container{     
    80%;
    height:100%;
    margin-left:10%;
    margin-right:10%;
    background:#ABE0F1;
    }
    /*头部*/
    #header{
    100%;
    height:15%;
    margin:0px;
    background:#FF0000;
    }
    
    #logo{
    float:left;    /*浮动属性,居左对齐,使其能够在同一行显示*/
    60%;
    height:80%;
    margin:0px;
    background:#E18CDD;
    clear:left;     /*取消左側浮动*/
    }
    #banner{
    float:right;   /*浮动属性,居右对齐,使其能够在同一行显示*/
    38%;
    height:80%;
    margin:0px;
    background:#8376D8;
    clear:right;    /*取消右側浮动*/
    }
    #menu{
    100%;
    height:5%;
    margin:0px;
    background:#00FF00;
    }
    #pageBody{
    100%;
    height:70%;
    margin:0px;
    background:#00FFFF;
    -moz-column-count:4;       /*多栏布局:火狐浏览器中须要的格式,表示列数*/
    -moz-column-gap:10px;      /*列之间的间隔*/
    -moz-column-rule:1px solid red;   /*在列之间加一条红色的线*/
    
    -webkit-column-count:4;    /*多栏布局:safari和chrome须要的格式*/
    -webkit-column-gap:10px;   /*列之间的间隔*/
    -webkit-column-rule:1px solid red;   /*在列之间加一条红色的线*/
    }
    #footer{
    100%;
    height:10%;
    margin:0px;
    background:#FFFF00;
    }
    
    
    
    

    layout.html
    <!DOCTYPE>
    <html>
    <head>
    <meta charset="utf-8">
    <title>布局</title>
    <link href="style/layout.css" rel="stylesheet" type="text/css" />
    </head>
    
    <body>
    <div id="container">
       <div id="header">
           <div id="logo">
    	     logo
    	   </div>
    	   <div id="banner">
    	   banner
    	   </div>
    	   container
       </div>
       <div id="menu">
       menu
       </div>
       <div id="pageBody">
        内容省略
       </div>
       <div id="footer">
       footer
       </div>
    </div>
    </body>
    </html>
    

    效果图:


    盒子布局

    hezi.css
    /* CSS Document */
    
    /*基本信息*/
    body{
    margin:0px;  /*外边距*/
    text-align:center; /*文字居中对齐*/
    background:#E1D0BB;  /*背景色*/
    }
    /*页面层容器*/
    #container{     
    display:-moz-box;
    display:-webkit-box;
    }
    #left_side{
    200px;
    height:200px;
    margin:20px;
    padding:50px;
    background-color:#FF0000
    
    }
    #center_side{
    200px;
    height:200px;
    margin:20px;
    padding:50px;
    background-color:#00FF00
    }
    #right_side{
    200px;
    height:200px;
    margin:20px;
    padding:50px;
    background-color:#FFFF00;
    }
    #left_side,#center_side,#right_side{      /*实现盒子布局*/
    -moz-box-sizing:border-box;
    -webkit-box-sizing:border-box;
    }
    #down_left{
    -moz-box-flex:1;        /*可依据内容自己主动调整大小,实现弹性盒子。此为火狐下的格式*/
    -webkit-box-flex:1;
    padding:20px;
    margin:20px;
    background-color:blue;
    }
    #down_left{
    -moz-box-sizing:border-box;
    -webkit-box-sizing:border-box;
    }
    
    
    hexi.html
    <!DOCTYPE>
    <html>
    <head>
    <meta charset="utf-8">
    <title>布局</title>
    <link href="style/hezi.css" rel="stylesheet" type="text/css" />
    </head>
    
    <body>
    <div id="container">
      <div id="left_side">
      百度
      </div>
      <div id="center_side">
      谷歌
      </div>
      <div id="right_side">
      淘宝
      </div>
        <div id="down_left">
      亚马逊
      </div>
    </div>
    </body>
    </html>
    

    效果图:

    假设想要让盒子垂直分部,能够在将container改为:
    #container{     
    display:-moz-box;
    display:-webkit-box;
    -moz-box-orient:vertical;   /*垂直分布*/
    -webkit-box-orient:vertical;
    }

    这里仅给出了大致的布局方式。关于很多其它的属性,大家能够阅读相关的书籍和资料。




  • 相关阅读:
    html笔记
    Git入门学习总结
    使用OpenSSH远程管理Linux服务器
    Linux 网卡驱动的安装
    vi的使用
    Linux下常用的数据恢复工具
    网络文件系统(NFS)的使用
    文件系统管理
    磁盘存储管理
    用户权限管理
  • 原文地址:https://www.cnblogs.com/mqxnongmin/p/10667369.html
Copyright © 2011-2022 走看看