這篇文章主要介紹了原生ajax瀑布流的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
其中img文件夾中放入圖片 1.jpg;2.jpg;3.jpg....
ajax.php頁面
<?php //模擬從數據庫讀取數據 $arr = array(); $op = opendir('./img'); //打開目錄 //循環讀取目錄 while (($file = readdir($op)) !== false) { //過濾點和點點 if ($file == '.' || $file == '..') { continue; } $arr[] = $file; } closedir($op); //關閉目錄 echo json_encode($arr);
demo.html頁面
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>瀑布流</title> <style> li{ list-style: none; float: left; margin:4px; } img{ border:4px solid black; } </style> </head> <body> <ul id="ul"> <!-- <li><img src="./img/1.jpg" height="300" alt=""></li> --> </ul> </body> <script> //找對象 var ul = document.getElementById('ul'); //拿數據 function getData() { var ajax = new XMLHttpRequest(); ajax.open('get', 'ajax.php', true); ajax.send(); ajax.onreadystatechange = function() { if (ajax.readyState == 4 && ajax.status == 200) { var res = ajax.responseText; //處理結果 var obj = JSON.parse(res); for (var k in obj) { // obj[k]; //創建節點 var li = document.createElement('li'); li.innerHTML = '<img src="./img/'+obj[k]+'" height="300" />'; ul.appendChild(li); } } } } getData(); var timer; //判斷滾動條的高度,加載第二批文件 window.onscroll = function() { //獲取三高 var zGao = document.documentElement.scrollHeight;//總高度 var lGao = document.documentElement.clientHeight;//瀏覽器可用高度 var gGao = document.body.scrollTop || document.documentElement.scrollTop;//滾出去的高度 // console.log(zGao, lGao, gGao); document.title = zGao + '_' + lGao + '_' + gGao; if (zGao - lGao - gGao < 500) { clearTimeout(timer); //用一次性定時器解決連續加載的問題 timer = setTimeout(function(){ getData(); }, 200) } } </script> </html>
感謝你能夠認真閱讀完這篇文章,希望小編分享的“原生ajax瀑布流的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。