<div class="codetitle"> <span><a style="CURSOR: pointer" data="66439" class="copybut" id="copybut66439" onclick="doCopy('code66439')"><u>复制代码</u></a></span> 代码如下:</div> <div class="codebody" id="code66439"> <br> <br> <br> <br><meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <br><title>瀑布流布局代码</title> <br><script type="text/javascript" src="js/jquery.js"></script> <br><style type="text/css"> <BR>body, div, img, h1, h2, h3, h4, h5, h6 { padding:0px; margin:0px; } <BR>img { border:none; } <BR>.wrapper { width:960px; margin:0 auto; } <BR>#con1_1 { position:relative; } <BR>#con1_1 .product_list { position:absolute; left:0px; top:0px; padding:10px; background:#eee; } <BR>.product_list img { width:200px; display:block; } <BR>.product_list h2 { padding:5px 0px; font-size:12px; text-align:center; color:#333; } <BR></style> <br> <br> <br><div class="wrapper"> <br><h3>这是正文的标题部分</h3> <br><div id="con1_1"> <br><div class="product_list"> <a href="#"><img src="images/img1.jpg" alt="瀑布流布局代码一例_javascript技巧" ></a> <br><h2>图片高度</h2> <br> </div> <br><div class="product_list"> <a href="#"><img src="images/img2.jpg" alt="瀑布流布局代码一例_javascript技巧" ></a> <br><h2>图片高度</h2> <br> </div> <br><div class="product_list"> <a href="#"><img src="images/img3.jpg" alt="瀑布流布局代码一例_javascript技巧" ></a> <br><h2>图片高度</h2> <br> </div> <br><div class="product_list"> <a href="#"><img src="images/img4.jpg" alt="瀑布流布局代码一例_javascript技巧" ></a> <br><h2>图片高度</h2> <br> </div> <br><div class="product_list"> <a href="#"><img src="images/img5.jpg" alt="瀑布流布局代码一例_javascript技巧" ></a> <br><h2>图片高度</h2> <br> </div> <br><div class="product_list"> <a href="#"><img src="images/img6.jpg" alt="瀑布流布局代码一例_javascript技巧" ></a> <br><h2>图片高度</h2> <br> </div> <br><div class="product_list"> <a href="#"><img src="images/img7.jpg" alt="瀑布流布局代码一例_javascript技巧" ></a> <br><h2>图片高度</h2> <br> </div> <br><div class="product_list"> <a href="#"><img src="images/img8.jpg" alt="瀑布流布局代码一例_javascript技巧" ></a> <br><h2>图片高度</h2> <br> </div> <br> </div> <br><h3>这行文字的位置首先要用js去计算下上面内容的高度了</h3> <br> </div> <br> <br><script type="text/javascript"> <BR>/* <BR>原理:1.把所有的li的高度值放到数组里面 <BR>2.第一行的top都为0 <BR>3.计算高度值最小的值是哪个li <BR>4.把接下来的li放到那个li的下面 <BR>*/ <BR>var margin = 10;//设置间距 <BR>var li=$(".product_list");//区块名称 <BR>var li_W = li[0].offsetWidth+margin;//取区块的实际宽度 <BR>function liuxiaofan(){ <BR>var h=[];//记录区块高度的数组 <BR>var n = 960/li_W|0; <BR>for(var i = 0;i < li.length;i++) { <BR>li_H = li[i].offsetHeight;//获取每个li的高度 <BR>if(i < n) {//n是一行最多的li,所以小于n就是第一行了 <BR>max_H =Math.max.apply(null,h); <BR>h[i]=li_H;//把每个li放到数组里面 <BR>li.eq(i).css("top",0);//第一行的Li的top值为0 <BR>li.eq(i).css("left",i * li_W);//第i个li的左坐标就是i*li的宽度 <BR>} <BR>else{ <BR>min_H =Math.min.apply(null,h) ;//取得数组中的最小值,区块中高度值最小的那个 <BR>minKey = getarraykey(h, min_H);//最小的值对应的指针 <BR>h[minKey] += li_H+margin ;//加上新高度后更新高度值 <BR>li.eq(i).css("top",min_H+margin);//先得到高度最小的Li,然后把接下来的li放到它的下面 <BR>li.eq(i).css("left",minKey * li_W); //第i个li的左坐标就是i*li的宽度 <BR>} <BR>$("h2").eq(i).text("高度:"+li_H);//把区块高度值写入对应的区块H2标题里面 <BR>} <BR>max =Math.max.apply(null,h) ; <BR>$("#con1_1").css("height",max); <BR>} <BR>/* 使用for in运算返回数组中某一值的对应项数(比如算出最小的高度值是数组里面的第几个) */ <BR>function getarraykey(s, v) {for(k in s) {if(s[k] == v) {return k;}}} <BR>/*这里一定要用onload,因为图片不加载完就不知道高度值*/ <BR>window.onload = function() {liuxiaofan();}; <BR>window.onresize = function() {liuxiaofan();}; <br><br><BR>$(function(){ <BR>$(".product_list").hover(function(){ <BR>$(this).css("background-color","#ddd"); <BR>},function() { <BR>$(this).css("background-color","#eee"); <BR>}); <BR>}); <BR></script> <br> <br> </div>