(转)Div左右两侧等高

一. 利用背景图,做出左右等高的模拟效果  

这种方法不是真正的左右等高,而是在外框元素中添加一张背景图片,当内容增多时,背景会纵向重复,就会形成左右等高的效果。

这种方法不是真正的div自动等高,而是在左右两个div的外面添加一个外框元素,给这个外框元素添加一个背景,当内容增多时,背景就会向下纵向重复,看起来就向左右两个div都自动向下延伸了一样。下面写一下详细代码。

Html代码:

<div id="wrap">

<div id="left_a">

<p>http://Dreamweaver.abang.com</p><p>http://Dreamweaver.abang.com</p>

<p>http://Dreamweaver.abang.com</p><p>http://Dreamweaver.abang.com</p>

<p>http://Dreamweaver.abang.com</p><p>http://Dreamweaver.abang.com</p>

<p>http://Dreamweaver.abang.com</p><p>http://Dreamweaver.abang.com</p>

<p>http://Dreamweaver.abang.com</p>

</div>

<div id="right_a">

<br /> <br />

<br /> <br />

<br /> <br />

</div>

<div class="clear"></div>

</div>

CSS代码:

*{margin:0;     padding:0;}

#wrap{

width:950px;

height:100%;

clear:both;

margin:0 auto;

background:#FFF url(background.gif) repeat;

}

#left_a { float:left; width:190px; }

#right_a { float:right;    width:750px; }

.clear { clear:both; }

对以上代码的解释:

1、在Html代码中,<div id="wrap">这行是外面容器的开始,在CSS中用background给它定义一个背景;

2、给wrap定义背景的时候要注意,这里定义的总宽度是950像素,左侧边栏是190像素,右侧是750像素,两者中间有10像素的空白,制作背景图时应按照此尺寸制作,左侧190像素是一个颜色,右侧750像素是一个颜色,中间10像素白色。

3、由于这个布局采用的是float浮动布局的方式,两个div分别向左向右分布,很容易让浏览器解析时出现问题而检测不到高度,所以在CSS代码中,wrap的高度应定义为100%,并且使用clear方法清除浮动,让其在Firefox中也正常显示。

二. 利用表格嵌套 

这种方法就是在div中嵌套一个表格,因为表格是可以左右自动等高的,所以当一侧的内容增多时,两侧都会自动等高。

其实只要用表格布局做过页面,这个方法基本上大家都会,就是在div中嵌套表格。

原则上,使用div布局应尽量减少表格出现,但为了达到某些效果,稍稍的使用一些也是可以的,况且国外有些较有名的网站也使用了这种方法。下面讲解具体方法。

Html代码:

<div id="wrap">

<table border="0" cellpadding="0" cellspacing="0" id="table_layout">

<tr>

<td id="left_b">

<div class="box">

<p>http://Dreamweaver.abang.com</p><p>&nbsp;</p>

<p>http://Dreamweaver.abang.com</p><p>&nbsp;</p>

</div>

<div class="box">

<p>http://Dreamweaver.abang.com</p><p>&nbsp;</p>

<p>http://Dreamweaver.abang.com</p>

</div>

</td>

<td id="mid_b">&nbsp;</td>

<td id="right_b">

<div class="box">阿邦Dreamweaver专栏</div>

</td>

</tr>

</table>

</div>

CSS代码:

* { margin:0; padding:0; }

#wrap { width:950px; height:100%; clear:both; margin:0 auto; background:#FFF; color:#FFF; }

#table_layout { width:950px; }

#left_b { width:190px; background:#09C; }

#right_b { width:750px; background:#09C; }

#mid_b { width:10px; }

.box { clear:both; height:100%; }

上面的代码是将表格嵌套在wrap这个div中,在这个table中又插入其它div,这样就可以让左右两列达到自动等高的效果。上面的代码大家应该都能看懂,如果有问题可以向我提问。

三. 利用内、外补丁padding和margin自动等高 

这种方法是利用正内补丁和负外补丁相结合,再隐藏掉溢出的内容,最终达到左右等高的效果。

具体理论不再多说了,只要把代码给大家列出来就能一目了然了。

Html代码:

<div id="wrap">

<div id="left">

<br /><br />

</div>

<div id="right">

http://Dreamweaver.abang.com <br />

<br /> <br /> <br />

阿邦Dreamweaver专栏 <br /> <br />

<br /> <br />

</div>

</div>

CSS代码:

* { margin:0; padding:0; }

#wrap{ overflow:hidden; padding:0; padding-left:180px; }

#left,#right{ height:auto; margin-bottom:-10000px; padding-bottom:10000px; }

#left{ display:inline; float:left; width:180px; margin-left:-180px; background: #0CF; }

#right{ float:right; width:100%; background: #FC6; }

个人优化,div自适应宽度css代码:

* { margin:0; padding:0; }

#wrap{ overflow:hidden; padding:0; }

#left,#right{ height:auto; margin-bottom:-10000px; padding-bottom:10000px; }

#left{ display:inline; float:left; width:180px; background: #0CF; }

#right{ background: #FC6; overflow: hidden; }

对以上代码的部分解释:

1、最外面的wrap必须使用overflow:hidden来隐藏溢出的内容。

2、wrap的左内补丁设置为180像素是为了让left这个div有空间显示。

3、left和right两个div底部外补丁为-10000px,底部内补丁为10000px,这是必须设置的,如果内容可能会较多,可以将数值再增大。

4、left这个div居左,right居右,display:inline属性是为了修正left在IE6中会跑出外框的bug。

四. 利用Javascript脚本 

Javascript是最好的Html辅助程序,尤其是前端界面的开发,在自动等高方面,也有专业的脚本。

网上使div等高的Javascript脚本很多,但有些仅仅针对IE浏览器可用,对Firefox、Opera等浏览器无效,所以在选择脚本的时候应该特别注意脚本的跨浏览器兼容性。

下面给大家介绍一个从网上找来的Javascript脚本,并列出使用方法。

Html代码:

<div class="div_top">

这是顶部的div

</div>

<div id="Div1" class="div_left">

左部div <br />

http://Dreamweaver.abang.com <br /><br />

<br /><br />

<br /><br />

</div>

<div id="Div2" class="div_right">

右部div <br/> http://Dreamweaver.abang.com <br/>

</div>

<div class="div_bottom">

这是底部的DIV

</div>

CSS代码:

* { margin:0px; padding:0px; }

.div_top{ width:100%; background:#FCC; }

.div_bottom{ width:100%; background:#FFC; }

.div_left{ position:absolute; width:200px; background:#FE2; }

.div_right{ margin-left:200px; background:#0CF; }

Javascript代码:

<script>

function P7_colH(){

var i,oh,hh,h=0,dA=document.p7eqc,an=document.p7eqa;

if(dA&&dA.length){

for(i=0;i<dA.length;i++){

dA[i].style.height=‘auto‘;

}

for(i=0;i<dA.length;i++){

oh=dA[i].offsetHeight;h=(oh>h)?oh:h;

}

for(i=0;i<dA.length;i++){

if(an){

dA[i].style.height=h+‘px‘;

}

else{

P7_eqA(dA[i].id,dA[i].offsetHeight,h);

}

}

if(an){

for(i=0;i<dA.length;i++){

hh=dA[i].offsetHeight;

if(hh>h){

dA[i].style.height=(h-(hh-h))+‘px‘;

}

}

}else{

document.p7eqa=1;

}

document.p7eqth=document.body.offsetHeight;

document.p7eqtw=document.body.offsetWidth;

}

}

function P7_eqT(){

if(document.p7eqth!=document.body.offsetHeight||document.p7eqtw!=document.body.offsetWidth){

P7_colH();

}

}

function P7_equalCols(){

if(document.getElementById){

document.p7eqc=new Array;

for(i=0;i<arguments.length;i++){

document.p7eqc[i]=document.getElementById(arguments[i]);

}

setInterval("P7_eqT()",10);

}

}

function P7_eqA(el,h,ht){

var sp=10,inc=10,nh=h,g=document.getElementById(el),oh=g.offsetHeight,ch=parseInt(g.style.height);

ch=(ch)?ch:h;

var ad=oh-ch,adT=ht-ad;

nh+=inc;

nh=(nh>adT)?adT:nh;

g.style.height=nh+‘px‘;

oh=g.offsetHeight;

if(oh>ht){

nh=(ht-(oh-ht));g.style.height=nh+‘px‘;

}

if(nh<adT){

setTimeout("P7_eqA(‘"+el+"‘,"+nh+","+ht+")",sp);

}

}

</script>

以上Html、CSS、Javascript三部分代码齐备后,还需要在网页的body标签处加入一行代码,

变成<body >, 其中Div1对应的是左侧div的id,Div2对应的是右侧的id

如果是三列布局,可以再自己增加内容,变成 <body >

将以上代码复制到网页文件中,即可实现div自动等高的效果了。

阿邦Dreamweaver专栏

(转)Div左右两侧等高

时间: 2024-10-13 15:50:52

(转)Div左右两侧等高的相关文章

里面的div没有设置宽高,用padding设置的50px来撑开宽高,这个时候就需要用position:absolute或者relative来让文本去掉继承的外层的整宽度

1. <!DOCTYPE html><html><head><style>*{margin:0px;padding:0px;}#div1{position: relative;height: 200px;width: 200px;margin: 100px;padding:10px;border: 1px solid black;} #div2{padding:50px;position: absolute;border: 1px solid black;b

body和普通div背景图宽高百分比的区别

body和普通div背景图的区别 background: url(//m.360buyimg.com/mobilecms/s220x220_jfs/t2746/167/831241799/299152/1731092b/5728423cNa16c83cb.jpg!q70.jpg);    background-size: 100% 100%;    position: absolute;    height: 100px;    width: 100%; 你给body这个设置,和给一般的div这

纯css实现div三列等高布局的最简单方法简化版/也可以多列

使用正padding和负margin对冲实现多列布局方法 这种方法很简单,就是在所有列中使用正的上.下padding和负的上.下margin,并在所有列外面加上一个容器,并设置overflow:hiden把溢出背景切掉. html代码 <div id="wrap"> <div id="left"> <p> left</p> <p> left</p> <p> left</p>

transform的妙用---实现div不定宽高垂直水平居中

transform的兼容性 transform的兼容性还是比较乐观的.IE9以下不兼容,IE9支持代替的-ms-transform属性不过只支持2D转换. 谷歌和Safari支持代替的-webkit-transform属性.IE9以上.火狐和欧朋是兼容的. transform 属性向元素应用 2D 或 3D 转换.该属性允许我们对元素进行旋转.缩放.移动或倾斜. 在此,可妙用其移动的属性. 遇见div不定宽和高垂直水平居中的问题.记得以前都是用js去实现.现在可以用 transform进行实现.

四种方法解决DIV高度自适应问题

本文和大家重点讨论一下解决DIV高度自适应的方法,这里主要从四个方面来向大家介绍,相信通过本文学习你对DIV高度自适应问题会有更加深刻的认识. DIV高度自适应 关于DIV高度的自适应,一直是个让人头疼的问题,整理了一下以前总结的方法,仅表示我也玩过. htmlcode: <div id="container"> <dividdivid="leftSide">这边的高度自适应右侧的高度</div> <dividdivid=&

Div+Css布局遇到的常见问题

IE的问题: 一.双边距问题浮动元素的外边距会加倍,但与第一个浮动元素相邻的其他浮动元素外边距不会加倍.解决方法:在此浮动元素增加样式  display:inline; 二.图片产生的间隙父元素直接包含<img>,这个图片下方会和父元素边缘产生间隙.解绝方法:1.在源代码中让</div>和<img>在同一行,因为那个间隙是由换行符产生的.2.给<img>添加样式  display:block; 三.最小高度问题块元素最小高度为10px,当高度定义小于10px

div:给div加滚动栏 div的滚动栏设置

今天做了个样例: div 的滚动栏问题: 两种方法: 一. <div style=" overflow:scroll; width:400px; height:400px;”></div> 记住宽和高一定要设置噢,否则不成的 只是在不超出时,会有以下的滚动栏,所以不是最好的选择 二. <div style=" overflow-y:auto; overflow-x:auto; width:400px; height:400px;”></div&

html中的div是什么意思?

<DIV>称为区隔标记.作用:设定字.画.表格等的摆放位置.当你把文字,图象,或其他的放在 DIV 中,它可称作为"DIV block",或"DIV element"或"CSS-layer",或干脆叫"layer".而中文我们把它称作"层次".所以当你以后看到这些名词的时候,你就知道它们是指一段在 DIV 中的 HTML. <DIV>应用于 Style Sheet(式样表)方面会更显

div 水平垂直居中

已知布局为如下: <div id="container"> <p>test</p> <div id="center">12345</div> </div> 不知道宽和高的情况下: 方法一: #container{ position:relative; background:blue; } #center{ background:red; position:absolute; left:50%;