实际开发网站过程中边碰壁边积累了一些div+css布局相关的小技巧,在这里做一些整理与大家一起探讨。本文章将间歇性更新。

1.div+css布局综述

div+css布局个人观点就是“盒子套盒子”的关系,body作为整个页面是最大的盒,而在这个最大的盒里面的第一层子盒们构成了全局布局,在这些子盒内部,又可能分出若干个盒以形成局部布局。因此,在规划一个网页的布局时,先区分出有哪些大的板块作为处于全局布局一级的大盒,再在这些大盒内部进行局部小盒子的布局以最终实现想要达到的页面布局效果。

例如,上面的布局图是比较常见的网页布局方式,A代表body,也即整个页面。这里强调整个页面是因为随着浏览器大小在用户的拖放下发生变化,body的大小长宽也在跟着改变,注意这一点有利于我们避免一些问题(如使用绝对定位(position:absolute)却忽略了body的可变性导致在拖放下网页结构发生变化),同时这一点也可以被我们所利用(下面会讲到)。其次,我们可以比较明显地知道第一层子盒总共有三个,分别为B、C、D盒,他们占据了网页的上、中和下部分。

一般而言,B部分常用于网页的页眉,显示logo和导航菜单等,C部分作为网页主体,是网页主要内容所在的位置,D部分作为页尾,提供关于版权备案信息及相关连接等信息。我们注意到,这三个部分并没有占满整个body,这是正常的,我们无法假设用户的屏幕大小以及其浏览器的实际显示大小,因此,合理的解决方案应该是让全局布局中的这些盒子居中放置,并给予呈现内容所需要的并且是合适的宽度值(为什么不需要高度值呢,因为网页是允许下拉滚动浏览的,而横向的滚动往往会引起用户的不满)。那么什么是合适的宽度值呢,笔记本电脑/台式机的屏幕一般横向的像素都可以达到1024px以上,因此,只要在这个范围内(比如980px这个常用的数值),都可以认为是合适的,然后让他们居中(通过设置margin:auto(或具体设置margin-left和margin-right:auto,在当前行只有一个元素时,设置auto可以让left和right一样大))。至于那些没有填满的部分,可以对body使用恰当的背景色或背景图片解决。

三个全局盒内部的布局通常称为局部布局(其实我们会发现,全局和局部都是相对而言的),他们是真正考验布局能力的地方,而这其间所涉及到的一些技巧也是我写这篇博客的原因。

2.关于div

div标签的用途在于将一个或若干个元素组合成一个块级(有关块级与非块级元素可以参考http://www.cnblogs.com/double-bin/archive/2011/12/19/2293090.html)整体,从而我们可以在布局中把一些元素作为一个整体集合来操纵(比如这些元素之间的相对位置要求固定,且他们与集合外元素之间的位置关系是通过这个集合来反应的),同时,这也有利于我们对这些元素之间的相对位置采取更方便的布局策略(比如,有一个<a>希望跟着一个<span>动而动,那么我们就应该为它们建立一个div以包裹他们从而实现对他们的绑定)。

注意到html/css中的很多属性都是相对父元素而言的(如使用百分比定义width、height时,与父元素直接接触元素的margin属性等),因此用一个div包裹一些元素也为利用这一点提供了条件(比如有时我们希望两个按钮(也可以是<a>)保持一定比率的大小关系,那么给他们一个div包裹起来,让width、height属性是父元素的百分比即可控制这一点)。此外,局部布局中,一个元素的定位也往往是通过跟父元素的margin关系得到。

div+css布局记扎的更多相关文章

  1. DIV+CSS布局中主要CSS属性介绍

    Float: Float属性是DIV+CSS布局中最基本也是最常用的属性,用于实现多列功能,我们知道<div>标签默认一行只能显示一个,而使用Float属性可以实现一行显示多个div的功能 ...

  2. DIV+CSS布局网站基本框架

    html代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

  3. DIV CSS布局中position属性用法深入探究

    本文向大家描述一下DIV CSS布局中的position属性的用法,position属性主要有四种属性值,任何元素的默认position的属性值均是static,静态.这节课主要讲讲relative( ...

  4. DIV+CSS布局-固定页面开度布局

    DIV+CSS布局中主要CSS属性介绍: Float: Float属性是DIV+CSS布局中最基本也是最常用的属性,用于实现多列功能,我们知道<div>标签默认一行只能显示一个,而使用Fl ...

  5. SEO为什么要求网页设计师用DIV+CSS布局网页?

    问:SEO为什么要求网页设计师用DIV+CSS布局网页? 答:通常情况下,SEOer非常喜欢把一个网站做到最细节,在网页设计方面,有时与设计师沟通时,通常会问到:SEO为什么要求网页设计师用DIV+C ...

  6. DIV+CSS布局问题:一个宽度不确定的DIV里面放三个水平对齐的DIV,左右两个DIV宽度固定为150px,中间那个DIV充满剩余的宽度

    一个入门的DIV+CSS布局问题:一个宽度不确定的DIV里面放三个水平对齐的DIV,左右两个DIV宽度固定为150px,中间那个DIV充满剩余的宽度. 说明:代码非真实情况下使用,所以直接简单. 没耐 ...

  7. 一小时搞定DIV+CSS布局-固定页面开度布局

    本文讲解使用DIV+CSS布局最基本的内容,读完本文你讲会使用DIV+CSS进行简单的页面布局. 转载请标明:http://www.kwstu.com/ArticleView/divcss_20139 ...

  8. (转)div+css 布局经验 - 最简单的 = 最不变形的(原创技巧)

    站酷几年了 一直饱受其恩泽 尤为感激 一直想奉献些什么 但是苦于水平 苦于奔波 今天静下心来 为大家奉献下 自己的div+css 经验 ,以下观点只代表 深海个人立场 希望为初学者提供一条" ...

  9. (转)一小时搞定DIV+CSS布局-固定页面开度布局

    本文讲解使用DIV+CSS布局最基本的内容,读完本文你讲会使用DIV+CSS进行简单的页面布局. 转载请标明:http://www.kwstu.com/ArticleView/divcss_20139 ...

随机推荐

  1. 使用Groovy的mixin方法注入,和mixedIn属性实现过滤链

    mixin方法注入不多说,这里只是用这个属性搞一个过滤器链的功能 假设我现在有个方法,输入一个字符串,然后需求提出需要进行大写转换输出, 过了一天又要加个前缀,再过了一天,需要把一些字符过滤掉.... ...

  2. 【C++】获取URL中主机域名

    // ConsoleApplication1.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <windows.h& ...

  3. caffe中使用python定义新的层

    转载链接:http://withwsf.github.io/2016/04/14/Caffe-with-Python-Layer/ Caffe通过Boost中的Boost.Python模块来支持使用P ...

  4. 【Shell】带颜色输出(白底x色)

    echo -e "\033[31mHello World.\033[0m" 红色31m 绿色32m 黄色33m 蓝色34m 黑色30m 白色37m 紫色35m 深绿色36m

  5. Win7 启动修复

    先让我们看一下windows7的启动过程的常识:电脑加电后,首先是启动BIOS程序,BIOS自检完毕后,找到硬盘上的主引导记录MBR,MBR读取DPT(分区表),从中找出活动的主分区,然后读取活动主分 ...

  6. vue学习生命周期(created和mounted区别)

    created:在模板渲染成html前调用,即通常初始化某些属性值,然后再渲染成视图(例如ajax请求列表). mounted:在模板渲染成html后调用,通常是初始化页面完成后,再对html的dom ...

  7. ES系列六、ES字段类型及ES内置analyzer分析

    一.背景知识 在Es中,字段的类型很关键: 在索引的时候,如果字段第一次出现,会自动识别某个类型,这种规则之前已经讲过了. 那么如果一个字段已经存在了,并且设置为某个类型.再来一条数据,字段的数据不与 ...

  8. CentOS如何设置终端显示字符界面区域的大小

    红框内的文字本应该在上一行后方,调了stty也不行, stty size的值变化,但显示还是没变化 后来参考http://www.jb51.net/os/RedHat/522217.html 修改 / ...

  9. nagios监控客户端报错/usr/bin/perl^M: bad interpreter: No such file or directory

    nagios服务端监控客户端内存时发现监控不上 在客户端直接执行脚本,报错如下: # /usr/local/nagios/libexec/check_memory.pl -w 6% -c 3% -ba ...

  10. 前端web服务器数据同步方案

    概述: 网站采用了web和mysql数据库分离的架构,前端有web1.web2.web3需要对他们进行上传文件同步 方案: 在web2的windows服务器上安装GoodSync软件,利用其双向同步特 ...