您好,登錄后才能下訂單哦!
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
*{margin: 0;padding: 0;}
#wrap{width: 90%;margin: 10px auto;border: 1px solid;}
.pics{width: 200px;padding: 5px;border: 1px solid #ddd;margin-top: 15px;left: 0;top: 0;}
.pics img{width: 200px;display: block;}
</style>
<script src="jquery-1.12.4.js"></script>
<script>
$(function(){
var position = []; //聲明一個(gè)空數(shù)組,存放各列高度
$(window).on('load resize',function(){
var wrapWidth = $('#wrap').innerWidth(), //容器的寬度
$pics = $('.pics'),
picsWidth = $pics.eq(0).outerWidth(),
cols = Math.floor(wrapWidth / picsWidth),//每行的列數(shù)
spacing = (wrapWidth - picsWidth * cols) / (cols + 1),
html =''; //用於保存中間處理過(guò)程中的html字符串
/*=================按最短列添加================*/
//循環(huán)向wrap中存放cols個(gè)列盒子
for(i=0; i<cols; i++){
html += "<div style='display:inline-block; width:"+picsWidth+"px; margin-left:"+spacing+"px; vertical-align:top;'></div>";
}
var $wrapCols = $(html).appendTo('#wrap');
//遍歷所有的圖片并將它們按最短了的順序放在各個(gè)列div元素中
$pics.each(function(index,element){
if(index < cols){
position.push(0);
}
//查找最短列的索引值
var min = Math.min.apply(null,position), //position中的最小值 minIndex = $.inArray(min,position); //找出最短列的索引
$wrapCols.eq(minIndex).append(element); //將當(dāng)前圖片append到最短列
position[minIndex] += $(element).outerHeight(true); //重新計(jì)算minIndex列的高度
});
//ajax加載更多圖片 當(dāng)滾動(dòng)高度超過(guò)最短列時(shí)開始加載
var _page = 2,
isLoading = false; //是否是正在通過(guò)ajax加載圖片
$(window).on('scroll',function(){
var _scTop = $(this).scrollTop(),
minHeight = Math.min.apply(null,position),
winHeight = $(window).height(); //窗口高度
if(!isLoading && _scTop >= minHeight-winHeight){
isLoading = true;
$.ajax({
type:'get',
url:'http://apis.baidu.com/txapi/mvtp/meinv',
data:{'num':20},
headers:{'apikey':'your own apiey'}, //此處的apikey需要換成自己的apikey
dataType:'json',
success:function(data){
console.log(data);//先將responseText打印出來(lái)看一下長(zhǎng)什么樣子,方便我們進(jìn)一步對(duì)其進(jìn)行處理
var array = data.newslist,
html = '';
$.each(array,function(){
html += '<div class="pics"><img src="' + this.picUrl+ '" /></div>';
});
$(html).each(function(index,element){
$(this).children('img').on('load',function(){
var minIndex = $.inArray(Math.min.apply(null,position),position);
$('#wrap>div').eq(minIndex).append(element);
position[minIndex] += $(element).outerHeight(true);
});
});
isLoading = false; //可以繼續(xù)加載圖片
}
});
}
});
});
</script>
</head>
<body>
<div id="wrap">
<div class="pics"><img src="img3/1.jpg" alt="1" /></div>
<div class="pics"><img src="img3/2.jpg" alt="1" /></div>
<div class="pics"><img src="img3/3.jpg" alt="1" /></div>
<div class="pics"><img src="img3/4.jpg" alt="1" /></div>
<div class="pics"><img src="img3/5.jpg" alt="1" /></div>
<div class="pics"><img src="img3/6.jpg" alt="1" /></div>
<div class="pics"><img src="img3/7.jpg" alt="1" /></div>
<div class="pics"><img src="img3/8.jpg" alt="1" /></div>
<div class="pics"><img src="img3/9.jpg" alt="1" /></div>
<div class="pics"><img src="img3/10.jpg" alt="1" /></div>
<div class="pics"><img src="img3/11.jpg" alt="1" /></div>
<div class="pics"><img src="img3/12.jpg" alt="1" /></div>
<div class="pics"><img src="img3/13.jpg" alt="1" /></div>
<div class="pics"><img src="img3/14.jpg" alt="1" /></div>
<div class="pics"><img src="img3/15.jpg" alt="1" /></div>
<div class="pics"><img src="img3/16.jpg" alt="1" /></div>
<div class="pics"><img src="img3/17.jpg" alt="1" /></div>
<div class="pics"><img src="img3/18.jpg" alt="1" /></div>
</div>
</body>
</html>
<!--最后我們可以看到得到的responseText長(zhǎng)成下面圖片中的樣子,首先它是一個(gè)object,有3個(gè)屬性,分貝為code,msg和newslist。我們感興趣的是newslist,因?yàn)槔锩姹4媪苏?qǐng)求到的圖片對(duì)象,而且它是一個(gè)數(shù)組,它的picUrl屬性就是我們需要的圖片網(wǎng)絡(luò)地址。有了這些信息就可對(duì)它進(jìn)行處理了。詳細(xì)步驟見代碼,就不啰嗦了。
最后希望對(duì)大家有所幫助。-->
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。