好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

html5教程-我熟知的三种三栏网页宽度自适应布局方法

小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

&nbs p;

一、前言

在如今各个分辨率显示器N足鼎立的时期,页面采用流动性布局(亦可称自适应布局)不失为一个好选择。当然,具体实现不是那么容易,需要一定的css功力和实践经验。本文不讲细节,只讲外部的自适应架构,这也是实现整个页面自适应的前提。目前为止,我所熟知的左中右三栏宽度自适应于浏览器的方法有三个:绝对定位法,margin负值法以及自身浮动法。这些方法简洁实用,且无兼容性问题。如果您想在您的页面上使用流动性布局,相信本文给您一些启示的。

二、网页宽度自适应布局三种方法

为了演示的需要,首先限定下示例的布局结构:左中右三栏布局,左右两栏宽度固定(要想不固定将宽度值改为百分值即可),中间栏宽度自适应。左右两栏的宽度为 200 像素。

1、绝对定位法

这或许是三种方法里最直观,最容易理解的:左右两栏采用绝对定位,分别固定于页面的左右两侧,中间的主体栏用左右 margin 值撑开距离。于是实现了三栏自适应布局。

您可以狠狠地点击这里:绝对定位法演示demo

css代码如下(为截图):

HTML 代码为(图片):

这里的左中右三个 div 的顺序是可以任意 调整 的,这与剩下的两中方法就不一样了,需要注意一下。

此方法的优点是,理解容易,上手 简单 ,受内部元素影响而破坏布局的概率低,就是比较经得起折腾。
缺点在于:如果中间栏含有最小 宽 度限制,或是含有宽度的内部元素,当浏览器宽度小到一定程度,会发生层重叠的情况。然而,一般情况下,除非用户 显示器 分辨率宽度 >=1600 像素,否则用户不会把浏览器缩小到 1000 像素以下的,所以该缺陷 危害 指数3.

2、m arg in负值法

这种方法是在实际的网站中应用的最多的,我个人感觉多少有些跟风的嫌疑。此方法很难用一句话概括。首先,中间的 主体 要使用双层标签。外层 div 宽度 100% 显示,并且浮动(本例左浮动,下面所述依次为基础),内层 div 为真正的主体内容,含有左右 210 像素的 mar gin 值。左栏与右栏都是采用 margin 负值定位的,左栏左浮动, margin-left 为 -100% ,由于前面的div宽度100%与浏览器,所以这里的 -100% margin 值正好使左栏 div 定位到了页面的左侧;右侧栏也是左浮动,其 margin-left 也是负值,大小为其本身的宽度即 200 像素。

见下面的css代码:

HT ML 代码:

您可以狠狠地点击这里:margin负值法演示demo

您需要注意几个 div 的顺序,无论是左浮动还是右浮动,先是主体部分 div ,这是肯定的,至于左右两栏谁先谁后,都无所谓,我测试了IE6,Firefox,以及ch rom e浏览器,表现一致。

此方法的优点:三栏相互关联,可谓真正意义上的自适应,有一定的抗性——布局不易受内部影响。
缺点在于:相对比较难理解些,上手不容易,代码相对复杂。出现百分比宽度,过多的负值定位,如果出现布局的bug,排查不易。

3、自身浮动法

此方法代码最简单。应用了标签浮动跟随的特性。左栏左浮动,右栏右浮动,主体直接放后面,就实现了自适应。

您可以狠狠地点击这里:自身浮动法演示demo

CSS代码如下:

HTML代码:

这里三个 div 标签的顺序的关键是要把主体div放在最后,左右两栏 div 顺序任意。

此方法的优点是:代码足够简洁与高效
不足在于:中间主体存在克星, clear:both 属性。如果要使用此方法,需避免明显的clear样式。

三、下载
您可以狠狠地单击这里:demo打包下载(zip )

四、结语
Table表格可谓是自适应布局的利器,如今 GOOGLE 的产品页面,Yahoo等自适应页面都还是使用的 table 技 术 , 原因 在于 table 本身的自适应能力。然而,虽然它是Google,它是Yahoo,但是我依然很鄙视,您可以试试用firebug去看一下Google页面的HTML代码,unbelievable!层级多的惊人,代码真是多,臃肿!我过去 觉得 可能是某些功能之需,现在发现是追求技术,可扩展,自适应的副产物。我多次实践,可以非常肯定的说: div 完全可以取代 table 实现自适应布局。

本文提供的仅仅是我个人 知道 的 几种 自适应方法,其实,我相信,肯定还有其他的方法,这就需要你我对其关注思考并发现了。

(本文完)

觉得可用,就经常来吧! 欢迎评论哦!  html5教程 ,巧夺天工,精雕玉琢。小宝典献丑了!

总结

以上是 为你收集整理的 html5教程-我熟知的三种三栏网页宽度自适应布局方法 全部内容,希望文章能够帮你解决 html5教程-我熟知的三种三栏网页宽度自适应布局方法 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于html5教程-我熟知的三种三栏网页宽度自适应布局方法的详细内容...

  阅读:52次