Ajax
"htmlcode">
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
background: #352323 url(images/a.png);
}
img {
display: block;
}
section {
max-width: 95%;
margin: 0 auto;
overflow: hidden;
column-count: 5;
column-gap: 0;
column-fill: auto;
}
figure {
border: 2px solid pink;
margin: 0 5px 10px;
break-inside: avoid;
padding: 5px;
}
figure img {
width: 100%;
}
figcaption {
padding: 10px 0;
text-align: center;
font-weight: 900;
color: #a77869;
}
html部分:
通过js插入节点,因为后台不知道多少张图片
<section>
<!-- <figure>
<img src="/UploadFiles/2021-04-02/1.jpg">
js有两个部分,一个是我封装的ajax函数,和一些判断函数
第一部分
window.onload = function() {
var section = document.getElementsByTagName('section')[0];
//运行ajax函数;
ajax('get', 'active.php', 'num=10', function(data) {
//解析json对象
let img_data = JSON.parse(data);
console.log(img_data);
//循环建多少图片配多少标签
for (let i = 0; i < img_data.length; i++) {
//建立figure标签
let figure = document.createElement('figure');
//创建两个子元素img和figcaption,并赋值
let img = document.createElement('img');
img.src = img_data[i];
let figcaption = document.createElement('figcaption');
figcaption.innerHTML = '往后余生,风雪是你';
//插节点
figure.appendChild(img);
figure.appendChild(figcaption);
section.appendChild(figure);
}
});
document.onscroll = function() {
var scrollTop = document.documentElement.scrollTop; //距离网页高度
console.log(scrollTop);
// var ks = document.documentElement.clientHeight; //可是化窗口高度
var ks = window.innerHeight || document.documentElement.clientHeight; //可是化窗口高度/兼容方法
var ht = document.documentElement.offsetHeight; //html总高度
// console.log(ht);
if (scrollTop + 1 >= ht - ks) { //鼠标滚动的距离大于html总高度-窗口的距离(也就是html在可视窗口之下的总高度)时 触发函数;
//执行函数
ajax('get', 'active.php', 'num=10', function(data) {
//解析json对象
let img_data = JSON.parse(data);
console.log(img_data);
//循环建多少图片配多少标签
for (let i = 0; i < img_data.length; i++) {
//建立figure标签
let figure = document.createElement('figure');
//创建两个子元素img和figcaption,并赋值
let img = document.createElement('img');
img.src = img_data[i];
let figcaption = document.createElement('figcaption');
figcaption.innerHTML = '往后余生,风雪是你';
//插节点
figure.appendChild(img);
figure.appendChild(figcaption);
section.appendChild(figure);
}
});
}
}
};
第二部分:
/**
* ajax封装
* @param {string} mehod请求数据方法
* @param {string} url 请求地址
* @param {string} data 请求参数
* @param {[functiong]} success [请求成功之后执行的函数0]
* @return {[none]} none
*/
function ajax(mehod, url, data, success) {
var xhr = null;
if (window.XMLHttpRequest) {
xhr = new XMLHttpRequest();
} else {
xhr = new ActiveXObject("Microsoft.xmlhttp")
}
//如果有参数get方法需要拼接字符串url+"color: #ff0000">php后台数据
因为主要功能偏向前端,所以后端就通过本地文件载入的
<"Content-type:text/html;charset=utf-8");
$num = $_GET['num']; // api调用者传递的需要的图片页数
$img = file("img.txt");
// var_dump($img);
$array_url = array();
for($i=0;$i<$num;$i++){
$url = array_rand($img);
array_push($array_url,$img[$url]);
}
$a = json_encode($array_url);
echo $a;
总结
以上所述是小编给大家介绍的JS通过ajax + 多列布局 + 自动加载来实现瀑布流效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
内蒙古资源网 Copyright www.nmgbbs.com
暂无“JS通过ajax + 多列布局 + 自动加载实现瀑布流效果”评论...
