脚本控制三行三列自适应高度DIV布局

所属分类: 网络编程 / CSS/HTML 阅读数: 2060
收藏 0 赞 0 分享
这个例子是用JS脚本控制并列DIV的高度,通常在DIV布局中,自适应高度一直是比较头疼的问题,一般大都采用背景图、外套DIV、右栏覆盖左栏......来解决。现在加了脚本后,简单多了,假如有三个水平并列的DIV,fbox、mbox、 sbox,只要在<body>标签中写入:onload="P7_equalCols('fbox','mbox','sbox')",测试条件:ie5.x、ie6.0、FF1.03、NS7.2、opera8.01。最终效果

JS代码:版权归原作者 ,仅供学习研究. 
复制代码 代码如下:

/* 
------------------------------------------------ 
PVII Equal CSS Columns scripts 
Copyright (c) 2005 Project Seven Development 
www.projectseven.com 
Version: 1.5.0 
------------------------------------------------ 
*/ 
function P7_colH(){ //v1.5 by PVII-www.projectseven.com 
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(){ //v1.5 by PVII-www.projectseven.com 
if(document.p7eqth!=document.body.offsetHeight||document.p7eqtw! =document.body.offsetWidth){ 
P7_colH();} 

function P7_equalCols(){ //v1.5 by PVII-www.projectseven.com 
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){ //v1.5 by PVII-www.projectseven.com 
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);} 



[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
更多精彩内容其他人还在看

最窄770px最宽1024px的经典布局研究

最窄770px最宽1024px的经典布局研究
收藏 0 赞 0 分享

CSS使用心得体会

CSS使用心得体会
收藏 0 赞 0 分享

用CSS实现链接的虚线下划线效果

一些CSS定义虚线实例代码
收藏 0 赞 0 分享

动态CSS站点教程:多个页面样式提供浏览者选择

动态CSS站点教程:多个页面样式提供浏览者选择
收藏 0 赞 0 分享

鲜为人知的CSS技巧10则

鲜为人知的CSS技巧10则
收藏 0 赞 0 分享

快速制作CSS导航菜单教

快速制作CSS导航菜单教
收藏 0 赞 0 分享

给图片在博客中添加滤镜效果

给图片在博客中添加滤镜效果
收藏 0 赞 0 分享

DIV+CSS网页制作布局技巧学习

DIV+CSS网页制作布局技巧学习
收藏 0 赞 0 分享

详谈 CSS样式表使用:链接/嵌入

详谈 CSS样式表使用:链接/嵌入
收藏 0 赞 0 分享

表格隔行换色 css expression

表格隔行换色 css expression
收藏 0 赞 0 分享
查看更多