JS通過ajax + 多列布局 + 自動加載實現(xiàn)瀑布流效果
Ajax
•說明:本文效果是無限加載的,意思就是你一直滾動就會一直加載圖片出現(xiàn),通過鼠標滾動距離來判斷的,所以不是說的那種加載一次就停了的那種,那種demo下次我會再做一次
css部分用的是html5+css3的新屬性,圖片會自動添加到每行的最頂端上去,而不是用js去判斷。去除了一些js計算的麻煩。
css部分:
* {
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插入節(jié)點,因為后臺不知道多少張圖片
<section>
<!-- <figure>
<img src="images/1.jpg" alt="">
<figcaption>往后余生,風雪是你</figcaption>
</figure> -->
</section>js有兩個部分,一個是我封裝的ajax函數(shù),和一些判斷函數(shù)
第一部分
window.onload = function() {
var section = document.getElementsByTagName('section')[0];
//運行ajax函數(shù);
ajax('get', 'active.php', 'num=10', function(data) {
//解析json對象
let img_data = JSON.parse(data);
console.log(img_data);
//循環(huán)建多少圖片配多少標簽
for (let i = 0; i < img_data.length; i++) {
//建立figure標簽
let figure = document.createElement('figure');
//創(chuàng)建兩個子元素img和figcaption,并賦值
let img = document.createElement('img');
img.src = img_data[i];
let figcaption = document.createElement('figcaption');
figcaption.innerHTML = '往后余生,風雪是你';
//插節(jié)點
figure.appendChild(img);
figure.appendChild(figcaption);
section.appendChild(figure);
}
});
document.onscroll = function() {
var scrollTop = document.documentElement.scrollTop; //距離網(wǎng)頁高度
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在可視窗口之下的總高度)時 觸發(fā)函數(shù);
//執(zhí)行函數(shù)
ajax('get', 'active.php', 'num=10', function(data) {
//解析json對象
let img_data = JSON.parse(data);
console.log(img_data);
//循環(huán)建多少圖片配多少標簽
for (let i = 0; i < img_data.length; i++) {
//建立figure標簽
let figure = document.createElement('figure');
//創(chuàng)建兩個子元素img和figcaption,并賦值
let img = document.createElement('img');
img.src = img_data[i];
let figcaption = document.createElement('figcaption');
figcaption.innerHTML = '往后余生,風雪是你';
//插節(jié)點
figure.appendChild(img);
figure.appendChild(figcaption);
section.appendChild(figure);
}
});
}
}
};第二部分:
/**
* ajax封裝
* @param {string} mehod請求數(shù)據(jù)方法
* @param {string} url 請求地址
* @param {string} data 請求參數(shù)
* @param {[functiong]} success [請求成功之后執(zhí)行的函數(shù)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")
}
//如果有參數(shù)get方法需要拼接字符串url+?+data
if (mehod === 'get' && data) {
url += '?' + data;
}
//open方法
xhr.open(mehod, url, true);
//send方法
if (mehod === 'get') {
xhr.send();
} else {
xhr.setRequestHeader('content-type', 'application/x-www-form-urlencoded');
xhr(data);
}
xhr.onreadystatechange = function() {
if (xhr.readyState === 4 && xhr.status === 200) {
success && success(xhr.responseText);
}
}php后臺數(shù)據(jù)
因為主要功能偏向前端,所以后端就通過本地文件載入的
<?php
header("Content-type:text/html;charset=utf-8");
$num = $_GET['num']; // api調(diào)用者傳遞的需要的圖片頁數(shù)
$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;總結(jié)
以上所述是小編給大家介紹的JS通過ajax + 多列布局 + 自動加載來實現(xiàn)瀑布流效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關文章
js鍵盤方向鍵 文章翻頁跳轉(zhuǎn)的效果[小說站常用已支持firefox]
一些小說或圖片類網(wǎng)站,為了方便大家閱讀,往往會加入利用鍵盤方向鍵進行翻頁、返回上一級、返回目錄、回首頁等功能。2009-05-05
JavaScript設計模式--簡單工廠模式實例分析【XHR工廠案例】
這篇文章主要介紹了JavaScript設計模式--簡單工廠模式,結(jié)合實例形式分析了JavaScript設計模式中簡單工廠模式原理與XHR工廠應用案例,需要的朋友可以參考下2020-05-05
基于layui數(shù)據(jù)表格以及傳數(shù)據(jù)的方式
今天小編就為大家分享一篇基于layui數(shù)據(jù)表格以及傳數(shù)據(jù)的方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08

