什么是CSS的盒子模式呢?为什么叫它是盒子?先说说我们在网页设计中常听的属性名:内容(content)、填充(padding)、边框(border)、边界(margin), CSS盒子模式都具备这些属性。

  这些属性我们可以把它转移到我们日常生活中的盒子(箱子)上来理解,日常生活中所见的盒子也具有这些属性,所以叫它盒子模式。那么内容就是盒子里装的东西;而填充就是怕盒子里装的东西(贵重的)损坏而添加的泡沫或者其它抗震的辅料;边框就是盒子本身了;至于边界则说明盒子摆放的时候的不能全部堆在一起,要留一定空隙保持通风,同时也为了方便取出嘛。在网页设计上,内容常指文字、图片等元素,但是也可以是小盒子(DIV嵌套),与现实生活中盒子不同的是,现实生活中的东西一般不能大于盒子,否则盒子会被撑坏的,而CSS盒子具有弹性,里面的东西大过盒子本身最多把它撑大,但它不会损坏的。填充只有宽度属性,可以理解为生活中盒子里的抗震辅料厚度,而边框有大小和颜色之分,我们又可以理解为生活中所见盒子的厚度以及这个盒子是用什么颜色材料做成的,边界就是该盒子与其它东西要保留多大距离。

  用div来定义语义结构

  现在我要给大家演示的是一个典型的版面分栏结构,即页头、导航栏、内容、版权(如下图)

  其结构代码如下:

  <div id="header"></div>

  <div id="nav"></div>

  <div id="content"></div>

  <div id="footer"></div>

  上面我们定义了四个盒子,按照我们想要的结果是,我们要让这些盒子等宽,并从下到下整齐排列,然后在整个页面中居中对齐,为了方便控制,我们再把这四个盒子装进一个更大的盒子,这个盒子就是BODY,这样代码就变成:

  <body>

  <div id="header"></div>

  <div id="nav"></div>

  <div id="content"></div>

  <div id="footer"></div>

  </body>

  最外边的大盒子(装着小盒子的大盒子)我们要让它在页面居中,并重定义其宽度为760像素,同时加上边框,那么它的样式是:

  body {

  font-family: Arial, Helvetica, sans-serif;

  font-size: 12px;

  margin: 0px auto;

  height: auto;

  width: 760px;

  border: 1px solid #006633;

  }

  页头为了简单起见,我们这里只要让它整个区块应用一幅背景图就行了,并在其下边界设计定一定间隙,目的是让页头的图像不要和下面要做的导航栏连在一起,这样也是为了美观。其样式代码为:

  #header {

  height: 100px;

  width: 760px;

  background-image: url(headPic.gif);

  background-repeat: no-repeat;

  margin:0px 0px 3px 0px;

  }

  导航栏我做成像一个个小按钮,鼠标移上去会改变按钮背景色和字体色,那么这些小小的按钮我们又可以理解为小盒子,如此一来这是一个盒子嵌套问题了,样式代码如下:

  #nav {

  height: 25px;

  width: 760px;

  font-size: 14px;

  list-style-type: none;

  }

  #nav li {

  float:left;

  }

  #nav li a{

  color:#000000;

  text-decoration:none;

  padding-top:4px;

  display:block;

  width:97px;

  height:22px;

  text-align:center;

  background-color: #009966;

  margin-left:2px;

  }

  #nav li a:hover{

  background-color:#006633;

  color:#FFFFFF;

  }

  内容部分主要放入文章内容,有标题和段落,标题加粗,为了规范化,我用H标签,段落要自动实现首行缩进2个字,同时所有内容看起来要和外层大盒子边框有一定距离,这里用填充。内容区块样式代码为:

  #content {

  height:auto;

  width: 740px;

  line-height: 1.5em;

  padding: 10px;

  }

  #content p {

  text-indent: 2em;

  }

  #content h3 {

  font-size: 16px;

  margin: 10px;

  版权栏,给它加个背景,与页头相映,里面文字要自动居中对齐,有多行内容时,行间距合适,这里的链接样式也可以单独指定,我这里就不做了。其样式代码如下:

  #footer {

  height: 50px;

  width: 740px;

  line-height: 2em;

  text-align: center;

  background-color: #009966;

  padding: 10px;

  }

  最后回到样式开头大家会看到这样的样式代码:

  * {

  margin: 0px;

  padding: 0px;

  }

  这是用了通配符初始化各标签边界和填充,(因为有部分标签默认会有一定的边界,如Form标签)那么接下来就不用对每个标签再加以这样的控制,这可以在一定程度上简化代码。最终完成全部样式代码是这样的:

  <style type="text/css">

  <!--

  * {

  margin: 0px;

  padding: 0px;

  }

  body {

  font-family: Arial, Helvetica, sans-serif;

  font-size: 12px;

  margin: 0px auto;

  height: auto;

  width: 760px;

  border: 1px solid #006633;

  }

  #header {

  height: 100px;

  width: 760px;

  background-image: url(headPic.gif);

  background-repeat: no-repeat;

  margin:0px 0px 3px 0px;

  }

  #nav {

  height: 25px;

  width: 760px;

  font-size: 14px;

  list-style-type: none;

  }

  #nav li {

  float:left;

  }

  #nav li a{

  color:#000000;

  text-decoration:none;

  padding-top:4px;

  display:block;

  width:97px;

  height:22px;

  text-align:center;

  background-color: #009966;

  margin-left:2px;

  }

  #nav li a:hover{

  background-color:#006633;

  color:#FFFFFF;

  }

  #content {

  height:auto;

  width: 740px;

  line-height: 1.5em;

  padding: 10px;

  }

  #content p {

  text-indent: 2em;

  }

  #content h3 {

  font-size: 16px;

  margin: 10px;

  }

  #footer {

  height: 50px;

  width: 740px;

  line-height: 2em;

  text-align: center;

  background-color: #009966;

  padding: 10px;

  }

  -->

  </style>

  结构代码是这样的:

  <body>

  <div id="header"></div>

  <ul id="nav">

  <li><a href="#">首 页</a></li>

  <li><a href="#">文 章</a></li>

  <li><a href="#">相册</a></li>

  <li><a href="#">Blog</a></li>

  <li><a href="#">论 坛</a></li>

  <li><a href="#">帮助</a></li>

  </ul>

  <div id="content">

  <h3>前言</h3>

  <p>第一段内容</p>

  <h3>理解CSS盒子模式</h3>

  <p>第二段内容</p>

  </div>

  <div id="footer">

  <p>关于华升 | 广告服务 | 华升招聘 | 客服中心 | Q Q留言 | 网站管理 | 会员登录 | 购物车</p><p>Copyright ?2006 - 2008 Tang Guohui. All Rights Reserved</p>

  </div>

  </body>

---更多SEO知识博客请浏览:雨田SEOER

css盒子模型详解一的更多相关文章

  1. CSS盒模型详解(图文教程)

    本文最初发表于博客园,并在GitHub上持续更新.以下是正文. 盒子模型 前言 盒子模型,英文即box model.无论是div.span.还是a都是盒子. 但是,图片.表单元素一律看作是文本,它们并 ...

  2. CSS中的盒子模型详解

    很多人对盒子模型搞晕头了,下面通过一个简单的代码来分析盒子模型的结构! 为了方便方便观看!在第一个div中画了一个表格,并将其尺寸设置成与div内容大小一样!且设置body的margin和paddin ...

  3. 2017年总结的前端文章——CSS盒模型详解

    CSS的盒模型是CSS的基础,同时也是难点,这个问题经常在面试中会被问到,属于经典问题了.很多博客里讲得也很模糊不清,于是,我在这里重新整理一下. 可以认为每个html标签都是一个方块,然后这个方块又 ...

  4. web@css盒模型详解

    Margin(外边距) - 清除边框外的区域,外边距是透明的./*上 右 下 左*/ 上 左右 下 /*上下 左右*/ 四方 /Border(边框) - 围绕在内边距和内容外的边框.      可以用 ...

  5. CSS盒子模型之详解

    前言:        盒子模型是css中最核心的基础知识,理解了这个重要的概念才能更好的排版,进行页面布局.一.css盒子模型概念    CSS盒子模型 又称框模型 (Box Model) ,包含了元 ...

  6. css 06-CSS盒模型详解

    06-CSS盒模型详解 #盒子模型 #前言 盒子模型,英文即box model.无论是div.span.还是a都是盒子. 但是,图片.表单元素一律看作是文本,它们并不是盒子.这个很好理解,比如说,一张 ...

  7. ASP.NET Core的配置(2):配置模型详解

    在上面一章我们以实例演示的方式介绍了几种读取配置的几种方式,其中涉及到三个重要的对象,它们分别是承载结构化配置信息的Configuration,提供原始配置源数据的ConfigurationProvi ...

  8. 深入理解CSS盒子模型

    在CSS中浮动.定位和盒子模型,都是很核心的东西,其中盒子模型是CSS很重要基石之一,感觉还是很有必要把CSS盒子模型相关知识更新一下...... CSS盒子模型<BoxModel>示意图 ...

  9. [转]CSS hack大全&详解

    转自:CSS hack大全&详解 1.什么是CSS hack? CSS hack是通过在CSS样式中加入一些特殊的符号,让不同的浏览器识别不同的符号(什么样的浏览器识别什么样的符号是有标准的, ...

随机推荐

  1. 集合 Properties 的 简单例子(Spring)

    Java代码: package com.ioc; import java.util.Properties; public class Student { private String name; pr ...

  2. 【Vijos1412】多人背包(背包DP)

    题意:求0/1背包的前K优解总和 k<=50 v<=5000 n<=200 思路:日常刷水 归并即可,不用排序 ; ..,..,..]of longint; w,c,a,b:..]o ...

  3. 使用<sstream> 替代<stdio.h>

    c++ 字符串流 sstream(常用于格式转换)   使用stringstream对象简化类型转换C++标准库中的<sstream>提供了比ANSI C的<stdio.h>更 ...

  4. svn服务安装与配置

    SVN安装 centos系统下执行yum install subversion 创建项目 svnadmin create dxk-test 创建项目dxk-test 服务配置与权限控制 vim con ...

  5. PHP的Trait机制

    PHP的Trait机制 Trait介绍: 1.自PHP5.4起,PHP实现了一种代码复用的方法,称为trait.2.Trait是为类似PHP的单继承语言二准备的一种代码复用机制.3.Trait为了减少 ...

  6. jquery.fullPage.js全屏滚动插件

    注:本文内容复制于http://www.51xuediannao.com/js/jquery/jquery.fullPage.html 和 http://www.360doc.com/content/ ...

  7. AIO

    IBM® 市场 (英文) 提交   我的 IBM 站点导航   学习 开发 社区 学习 Java technology 内容   概览 简单介绍 Asynchronous I/O 开始简单的异步 I/ ...

  8. 果皇的矩阵[matrix]

    #1101. 果皇的矩阵[matrix] 题目描述 输入格式 一行两个数,表示 N,M. 输出格式 一行一个数,表示答案对 10^9+7 取模后的结果 样例 样例输入 3 3 样例输出 38 数据范围 ...

  9. File类 递归 获取目录下所有文件文件夹

    package com.xiwi; import java.io.*; import java.util.*; class file{ public static void main(String a ...

  10. CodeBlock换肤

    CodeBlock换肤 conf文件下载地址 我的是在D:\Program Files (x86)\CodeBlocks\AppData\codeblocks\default.conf 然后替换本地的 ...