原生ajax瀑布流demo分享(必看篇)
最近聽朋友們說起瀑布流挺多的,自己就去研究下了,一個(gè)簡(jiǎn)單的原生demo,分享給大家...
簡(jiǎn)單分為三個(gè)文檔,有詳細(xì)的注釋:img;ajax.php;demo.php
其中img文件夾中放入圖片 1.jpg;2.jpg;3.jpg....
ajax.php頁面
<?php //模擬從數(shù)據(jù)庫讀取數(shù)據(jù) $arr = array(); $op = opendir('./img'); //打開目錄 //循環(huán)讀取目錄 while (($file = readdir($op)) !== false) { //過濾點(diǎn)和點(diǎn)點(diǎn) if ($file == '.' || $file == '..') { continue; } $arr[] = $file; } closedir($op); //關(guān)閉目錄 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> //找對(duì)象 var ul = document.getElementById('ul'); //拿數(shù)據(jù) 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; //處理結(jié)果 var obj = JSON.parse(res); for (var k in obj) { // obj[k]; //創(chuàng)建節(jié)點(diǎn) var li = document.createElement('li'); li.innerHTML = '<img src="./img/'+obj[k]+'" height="300" />'; ul.appendChild(li); } } } } getData(); var timer; //判斷滾動(dòng)條的高度,加載第二批文件 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); //用一次性定時(shí)器解決連續(xù)加載的問題 timer = setTimeout(function(){ getData(); }, 200) } } </script> </html>
以上這篇原生ajax瀑布流demo分享(必看篇)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
ajax簡(jiǎn)介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了ajax基礎(chǔ)知識(shí)點(diǎn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06Ajax實(shí)現(xiàn)城市二級(jí)聯(lián)動(dòng)(二)
這篇文章主要為大家詳細(xì)介紹了Ajax實(shí)現(xiàn)城市二級(jí)聯(lián)動(dòng)的相關(guān)資料,將省份用ajax請(qǐng)求并渲染,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02Ajax如何進(jìn)行跨域請(qǐng)求?Ajax跨域請(qǐng)求的原理
Ajax如何進(jìn)行跨域請(qǐng)求?這篇文章主要為大家詳細(xì)介紹了Ajax跨域請(qǐng)求的原理,Ajax怎么樣做跨域請(qǐng)求?具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08java+jquery處理xml數(shù)據(jù)的方法
這篇文章主要介紹了java+jquery處理xml數(shù)據(jù)的方法,實(shí)例分析了Ajax處理XML數(shù)據(jù)的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02