真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

JavaScript實現(xiàn)無窮滾動加載數(shù)據(jù)

首先實現(xiàn)滾動要借助onscroll事件處理程序。

創(chuàng)新互聯(lián)建站堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站建設(shè)、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的涇縣網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

無窮滾動就是滑動滾動條,實現(xiàn)數(shù)據(jù)塊的無窮加載。

我們以瀑布流的布局來實現(xiàn)無窮加載。瀑布流就是一些等寬不等高的數(shù)據(jù)塊布局。在滾動條下拉時,它會進行加載。那么問題就是在判斷什么時候應(yīng)該加載。

JavaScript實現(xiàn)無窮滾動加載數(shù)據(jù)

我們首先應(yīng)該明白瀑布流布局的特點。它將下一個圖片總是放在當(dāng)前列數(shù)最低的那一列。所以當(dāng)加載最后一個藍(lán)色的圖片時,也就無疑是最后一個圖片了。所以要判斷該圖片加載到什么程度來觸發(fā)滾動事件。
圖上灰色的表示頁面的大小,后面藍(lán)色邊框表示窗口的大小。當(dāng)拖動滾動條時,灰色部分上移。我們希望頁面最后一個圖片(藍(lán)色圖片)加載一半時觸發(fā)滾動事件。那么就要形成參照。

下來寫代碼:

//檢測是否具備滾動條加載數(shù)據(jù)塊的條件
function checkScrollSlide(){
 var oparent = document.getElementById('main');
 var oBoxs = getByClass(oparent,'box');
 var scrollH = document.body.scrollTop || document.documentElement.scrollTop + document.body.clientHeight || document.documentElement.clientHeight;
 var lastBoxH = oBoxs[oBoxs.length - 1].offsetTop + Math.floor(oBoxs[oBoxs.length - 1].offsetHeight/2);

 return (lastBoxH < scrollH )? true : false;
}

getClass是根據(jù)類名查找元素集合的自己寫的函數(shù),待會兒會附上源碼

我們要進行加載的數(shù)據(jù)塊的格式是這樣的.每個圖片被一個class= pic的div包裹。最后整體屬于父元素main

首先我們要加載的數(shù)據(jù)塊應(yīng)該是從后臺傳過來的,在這里我們用json模擬一下就可以:

var DataIn = {"data":[{"src":'0.jpg'},{"src":'1.jpg'},{"src":'2.jpg'},{"src":'3.jpg'},{"src":'4.jpg'},{"src":'5.jpg'}]};

比如這個就是后臺傳過來的數(shù)據(jù)。

上面的函數(shù)返回一個布爾值,當(dāng)為true時,觸發(fā)滾動事件。

 window.onscroll = function(){
 var oparent = document.getElementById('main');
 //當(dāng)滿足加載條件時,就要向頁面中加載數(shù)據(jù)塊
 if(checkScrollSlide){
  for(var i = 0; i< DataIn.data.length; i++){
    var oBox = document.createElement('div');
    oBox.className = 'box';
    oparent.appendChild(oBox);

    var opic = document.createElement('div');
    opic.className = 'pic';
    oBox.appendChild(opic);

    var oImg = document.createElement('img');
    oImg.src = './images/'+DataIn.data[i].src;
    opic.appendChild(oImg);

   }
   waterFull('main','box');
  }
 }
}

附上源碼:

css和html






 瀑布流布局
 


js代碼:

window.onload = function(){
 waterFull('main','box');

 var DataIn = {"data":[{"src":'0.jpg'},{"src":'1.jpg'},{"src":'2.jpg'},{"src":'3.jpg'},{"src":'4.jpg'},{"src":'5.jpg'}]};
 window.onscroll = function(){
  var oparent = document.getElementById('main');
  if(checkScrollSlide){
   for(var i = 0; i< DataIn.data.length; i++){
    var oBox = document.createElement('div');
    oBox.className = 'box';
    oparent.appendChild(oBox);

    var opic = document.createElement('div');
    opic.className = 'pic';
    oBox.appendChild(opic);

    var oImg = document.createElement('img');
    oImg.src = './images/'+DataIn.data[i].src;
    opic.appendChild(oImg);

   }
   waterFull('main','box');
  }
 }
}

function waterFull(parent,children){
 var oParent = document.getElementById(parent);
 //var oBoxs = parent.querySelectorAll(".box");

  var oBoxs = getByClass(oParent,children);

 //計算整個頁面顯示的列數(shù)

 var oBoxW = oBoxs[0].offsetWidth;

 var cols = Math.floor(document.documentElement.clientWidth/oBoxW);

 //設(shè)置main的寬度,并且居中

 oParent.style.cssText = 'width:'+oBoxW * cols +'px; margin: 0 auto';

 //找出高度最小的圖片,將下一個圖片放在下面

 //定義一個數(shù)組,存放每一列的高度,初始化存的是第一行的所有列的高度

 var arrH = [];

 for(var i = 0; i< oBoxs.length ; i++){
  if(i < cols){
   arrH.push(oBoxs[i].offsetHeight);
  }
  else{
   var minH = Math.min.apply(null,arrH);

   var minIndex = getMinhIndex(arrH,minH);

   oBoxs[i].style.position = 'absolute';
   oBoxs[i].style.top= minH + 'px';
   //oBoxs[i].style.left = minIndex * oBoxW + 'px'; 
   oBoxs[i].style.left = oBoxs[minIndex].offsetLeft+'px';

   arrH[minIndex] += oBoxs[i].offsetHeight; 
  }
 }


}
function getByClass(parent,className){

 var boxArr = new Array();//用來獲取所有class為box的元素

 oElement = parent.getElementsByTagName('*');

 for (var i = 0; i 

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


當(dāng)前文章:JavaScript實現(xiàn)無窮滾動加載數(shù)據(jù)
網(wǎng)站網(wǎng)址:http://weahome.cn/article/pdgdio.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部