Ajax

  • 说明:本文效果是无限加载的,意思就是你一直滚动就会一直加载图片出现,通过鼠标滚动距离来判断的,所以不是说的那种加载一次就停了的那种,那种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插入节点,因为后台不知道多少张图片

 <section>
<!-- <figure>
<img src="images/1.jpg" alt="">
<figcaption>往后余生,风雪是你</figcaption>
</figure> --> </section>

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+?+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后台数据

因为主要功能偏向前端,所以后端就通过本地文件载入的

<?php 

header("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 + 多列布局 + 自动加载来实现瀑布流效果的更多相关文章

  1. ASP.NET仿新浪微博下拉加载更多数据瀑布流效果

    闲来无事,琢磨着写点东西.貌似页面下拉加载数据,瀑布流的效果很火,各个网站都能见到各式各样的展示效果,原理大同小异.于是乎,决定自己写一写这个效果,希望能给比我还菜的菜鸟们一点参考价值. 在开始之前, ...

  2. 原生JS实现AJAX、JSONP及DOM加载完成事件,并提供对应方法

    JS原生AJAX ajax:一种请求数据的方式,不需要刷新整个页面: ajax的技术核心是 XMLHttpRequest 对象: ajax 请求过程:创建 XMLHttpRequest 对象.连接服务 ...

  3. 原生JS实现AJAX、JSONP及DOM加载完成事件

    一.JS原生Ajax ajax:一种请求数据的方式,不需要刷新整个页面:ajax的技术核心是 XMLHttpRequest 对象:ajax 请求过程:创建 XMLHttpRequest 对象.连接服务 ...

  4. js/jquery控制页面动态加载数据 滑动滚动条自动加载事件--转他人的

    js/jquery控制页面动态加载数据 滑动滚动条自动加载事件--转他人的 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样 ...

  5. ajax的使用:(ajaxReturn[ajax的返回方法]),(eval返回字符串);分页;第三方类(page.class.php)如何载入;自动加载函数库(functions);session如何防止跳过登录访问(构造函数说明)

    一.ajax例子:ajaxReturn("ok","eval")->thinkphp中ajax的返回值的方法,返回参数为ok,返回类型为eval(字符串) ...

  6. 只用css实现“每列四行,加载完一列后数据自动填充到下一列”的效果

    只用css实现“每列四行,加载完一列后数据自动填充到下一列”的效果.这个题目用图表示如下: 如果将题目换成“只用css实现每行四列,加载完一行后数据自动填充到下一行”,那这个问题就简单多了,相信大家都 ...

  7. [JS前端开发] js/jquery控制页面动态加载数据 滑动滚动条自动加载事件

    页面滚动动态加载数据,页面下拉自动加载内容 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样的效果:进入qq空间,向下拉动空 ...

  8. pace.js – 网页自动加载进度条插件

    网站顶部的页面加载进度条是怎么实现的,页面的加载进度百分比,有时候获取是比较麻烦的,当然也可以利用一些优秀的JavaScript插件来实现,今天就为大家介绍这样子的一款插件:pace.js. [官方网 ...

  9. 当滚动条滚动到页面底部自动加载增加内容的js代码

    这篇文章主要介绍了如何使用javscript实现滚动条滚动到页面底部自动加载增加页面内容,需要的朋友可以参考下..1,注册页面滚动事件,window.onscroll = function(){ }; ...

随机推荐

  1. CAD类型转换

    AcDbEntity *pEnt; AcDbCircle *pcir = AcDbCircle::cast(pEnt); static_cast<AcDbCircle*>(pEnt); p ...

  2. JpGraph 画图

    1:借鉴地址 PHP jpgraph安装及基本用法 http://www.php.cn/php-weizijiaocheng-400977.html JpGraph使用详解之中文乱码解决方法 http ...

  3. mysql异地备份方案经验总结

    Mysql 数据库异地备份脚本 实验环境:关闭防火墙不然不能授权登录 Mysql-server:192.168.30.25 Mysql-client:  192.168.30.24 实验要求:对mys ...

  4. mysql中having和where区别?

    having和where有相似之处但也有区别,都是设定条件的语句. 在查询过程中,聚合语句(sum,min,max,avg,count),要比having子句有限执行. 在查询过程中,要先执行wher ...

  5. react 子组件调用父组件方法

    import React from 'react'import '../page1/header.css'import { Table } from 'antd'import Child from ' ...

  6. copy.c实现

    #cat copy.c #include <stdio.h> #include <stdlib.h> #include <string.h> int copyFil ...

  7. P1352 没有上司的舞会——树形DP入门

    P1352 没有上司的舞会 题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员 ...

  8. 啥是SQL?

    SQL:(Structured Query Language)是结构化查询语言缩写.是一门专门与数据库管理系统打交道的语言. SQL语言:是关系型数据库的标准语言,,其主要用于存取数据,查询数据,更新 ...

  9. R 安装car包失败

    在RStudio里安装car包的时候报错 /usr/bin/ld: cannot find -llapack /usr/bin/ld: cannot find -lblas make: *** [qu ...

  10. linux学习2-压缩与解压

    1.zip 打包文件件 $ zip -r -q -o shiyanlou.zip /home/shiyanlou $ du -h shiyanlou.zip $ file shiyanlou.zip ...