原生ajax瀑布流demo分享(必看篇)
程序员文章站
2022-03-14 10:49:41
最近听朋友们说起瀑布流挺多的,自己就去研究下了,一个简单的原生demo,分享给大家...
简单分为三个文档,有详细的注释:img;ajax.php;demo.php
其...
最近听朋友们说起瀑布流挺多的,自己就去研究下了,一个简单的原生demo,分享给大家...
简单分为三个文档,有详细的注释:img;ajax.php;demo.php
其中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瀑布流demo分享(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。