2013-05-02
一夜之间 似乎互联网上出现了一种类似瀑布形式的网页布局,如美丽说、蘑菇街等网站都采用这种布局形式。常见的实现方法一般分为:传统多列浮动 、CSS3 定义、绝对定位。 笔者看到网上仅仅有关于CSS的详细教程,未见有绝对定位的相关教程。现在想和各位朋友们分享一下绝对定位的应用及具体代码,希望朋友们能够指出其中的不足之处。
JS的绝对定位分解成三个部分代码,这样清晰,方便查看代码,其中包括: Javascript代码、HTML代码、[AJax封装文件 代码。
[Javascript]代码
<script type="text/javascript" src="ajax.js"></script>
<script type="text/javascript">
window.onload=function()
{
var oDiv =document.getElementById("div");
var oUl=document.getElementsByTagName("ul");
window.onscroll=function()
{
var clientH=document.documentElement.clientHeight;
var scrollH=document.documentElement.scrollTop||document.body.scrollTop;
for(var i=0;i<oUl.length;i++)
{
var aLi=oUl[i].getElementsByTagName("li")
var lastL=aLi[aLi.length-1];
if(toTop(lastL)<clientH+scrollH)
{
ajax("a.js",function(str)
{
var json = eval('('+str+')')
for(var i=0;i<json.list.length;i++)
{
var list=json.list[i];
for(var j=0;j<list.src.length;j++)
{
var oLi=document.createElement("li")
oLi.innerHTML='<img src="'+list.src[j]+'"><p>'+list.title[j]+'</p>'
oUl[i].appendChild(oLi);
}
}
})
}
}
}
function toTop(obj)
{
var top=0;
while(obj)
{
top +=obj.offsetTop;
obj=obj.offsetParent
}
return top;
}
}
</script>
在html的head中,加入<script src="js/*.js" type="text/javascript"></script>
注:不能是<script src="js/*.js" type="text/javascript"/>JS部分处理完毕之后,接下来就是HTML代码部分的书写:
[HTML]代码
<div id='div'>
<ul>
<li>
<img src="images/1.jpg">
<p>11111111</p>
</li>
<li>
<img src="images/2.jpg">
<p>11111111</p>
</li>
<li>
<img src="images/3.jpg">
<p>11111111</p>
</li>
<li>
<img src="images/4.jpg">
<p>11111111</p>
</li>
</ul>
<ul>
<li>
<img src="images/5.jpg">
<p>11111111</p>
</li>
<li>
<img src="images/6.jpg">
<p>11111111</p>
</li>
</ul>
</div>
[AJax封装文件 ]代码
function ajax(url,sFn,nFn)
{
var oAjax=null;
if(window.ActiveXObject)
{
oAjax=new ActiveXObject("Microsoft.XMLHTTP")
}
else
{
oAjax=new XMLHttpRequest();
}
oAjax.open("GET",url,true)
oAjax.send();
oAjax.onreadystatechange=function()
{
if(oAjax.readyState==4)
{
if(oAjax.status==200)
{
if(sFn)
{
sFn(oAjax.responseText)
}
}
else
{
if(nFn)
{
nFn(oAjax.status)
}
}
}
}
}
当然,通过JS调用做瀑布式布局的方法还有很多,笔者仅列出一种,除了JS,jQuery的Masonry插件、KISSY的waterfall插件等都可以更加方便的实现效果。JS+HTML+封装代码已经给写出来了,供大家参考。JS虽然老了,但依旧千变万化,希望你能找到最适合自己的方法。
---------本文由郑州网站建设 http://www.zzwlgs.com在A5首发,转载请注明出处。
魂斗罗归来最新版本下载v1.74.125.3955 安卓手机版
射击枪战 1.94G
下载胜利女神妮姬国际服最新版下载v134.14.8 安卓官方版
射击枪战 123.0M
下载com.proximabeta.nikke手游(胜利女神nikke)下载v134.14.8 安卓版国际服
卡牌对战 123.0M
下载部落冲突皇室战争国际服下载v110449005 安卓正版
策略塔防 839.2M
下载宝宝上厕所宝宝巴士下载v9.87.00.01 安卓官方版
其它手游 105.0M
下载宝宝巴士奇妙世界美食小游戏下载v9.87.00.01 安卓版
其它手游 119.3M
下载宝宝手工零食宝宝巴士游戏下载v9.87.00.01 安卓最新版
其它手游 90.8M
下载逍遥情缘手游折扣平台下载v1.1.8 安卓版
其它手游 1.02G
下载海岛奇兵taptap下载v60.2.1 安卓版
下载
海滨消消乐2025春节版下载v1.119 安卓新春版
下载
海岛奇兵4399官方版下载v60.2.1 安卓最新版
下载
草花版海岛奇兵最新版下载v60.2.1 安卓版
下载
途游斗地主比赛版小游戏下载v3.5.0710 安卓版
下载
遇见你的猫ios版下载v2.15.0 iphone版
下载
网易uno手游下载v1.15.1553 安卓最新版
下载
宝宝冰淇淋工厂小游戏下载v9.87.00.01 安卓版
下载