HTML代码:

<div id="content">
<div class="box">
<div class="imgBox">
<a href="###"><img src="data:images/01.jpg" alt="" /></a>
</div>
</div>
<div class="box">
<div class="imgBox">
<a href="###"><img src="data:images/02.jpg" alt="" /></a>
</div>
</div>
<div class="box">
<div class="">
<a href="###"><img src="data:images/03.jpg" alt="" /></a>
</div>
</div>
<div class="box">
<div class="imgBox">
<a href="###"><img src="data:images/04.jpg" alt="" /></a>
</div>
</div>
<div class="box">
<div class="imgBox">
<a href="###"><img src="data:images/05.jpg" alt="" /></a>
</div>
</div>
<div class="box">
<div class="imgBox">
<a href="###"><img src="data:images/06.jpg" alt="" /></a>
</div>
</div>
<div class="box">
<div class="imgBox">
<a href="###"><img src="data:images/07.jpg" alt="" /></a>
</div>
</div>
<div class="box">
<div class="imgBox">
<a href="###"><img src="data:images/08.jpg" alt="" /></a>
</div>
</div>
<div class="box">
<div class="imgBox">
<a href="###"><img src="data:images/09.jpg" alt="" /></a>
</div>
</div>
<div class="box">
<div class="imgBox">
<a href="###"><img src="data:images/10.jpg" alt="" /></a>
</div>
</div>
</div>

CSS样式:

*{ margin:; padding:;}
body{ background-color:#f2f2f2;}
#content{ padding: 10px 0px; margin:0 auto; position:relative;}
.box{ padding:10px; width:310px; height:auto; float:left;}
.imgBox{ border:solid 1px #dcdcdc; width:310px;}
.imgBox img{ width:310px; height:auto;}

JS代码:

window.onload=function(){
setPosition('content','box');
//通过json字符串模拟加载内容
var imgArray={'date':[{'src':'05.jpg'},{'src':'06.jpg'},{'src':'07.jpg'},{'src':'08.jpg'}]} //滚动到页面底部(最后一张图片的顶部)时开始加载json内容
window.onscroll=function(){
if(getFlag()){ //判断是否滚动到最后一张
var oContent=document.getElementById('content'); //获取外部容器
for(var i=0;i<imgArray.date.length;i++){
var oDiv=document.createElement('div');
oDiv.className='box';
oContent.appendChild(oDiv);
var oImgDiv=document.createElement('div');
oImgDiv.className='imgBox';
oDiv.appendChild(oImgDiv);
var oImg=document.createElement('img');
oImg.src='images/'+imgArray.date[i].src;
oImgDiv.appendChild(oImg);
}
setPosition('content','box');
}
}
} //元素排列
function setPosition(parents,content){
var oContent=document.getElementById('content'); //获取外部容器
var aBox=getByClass(oContent,content); //获取classname为box的元素集合
var oneWidth=aBox[0].offsetWidth; //获取单个box的宽度
var docWidth=document.documentElement.clientWidth||document.body.clientWidth; //获取窗口可视区域宽度
var num=Math.floor(docWidth/oneWidth);
oContent.style.width=num*oneWidth+'px'; //设置外部容器的宽度
var result=[];
for(var i=0;i<aBox.length; i++){
if(i<num){
result[i]=aBox[i].offsetHeight; //判断是否为第一行,然后把第一行中每个aBox的高度存入定义的result数组中
}else{
var minHeight=Math.min.apply(null,result); //获取result数组中最小的值
var minIndex=getIndex(result,minHeight); //获取result数组中最小值的索引
aBox[i].style.position='absolute';
aBox[i].style.top=minHeight+10+'px';
aBox[i].style.left=aBox[minIndex].offsetLeft+'px';
result[minIndex]=result[minIndex]+aBox[i].offsetHeight;
}
}
}
//获取当前索引值
function getIndex(parents,name){
for(var i=0;i<parents.length;i++){
if(parents[i]==name){
return i;
}
}
}
//通过class选取元素方法
function getByClass(oParent,name){
var result=[];
var aArr=oParent.getElementsByTagName('*');
for(var i=0; i<aArr.length; i++){
if(aArr[i].className==name){
result.push(aArr[i]);
}
}
return result;
}
//判断是否滚动到最后
function getFlag(){
var oContent=document.getElementById('content');
var aBox=getByClass(oContent,'box');
var lastTop=aBox[aBox.length-1].offsetTop;
var clientHeight=document.documentElement.clientHeight||document.body.clientHeight;
var scorllTop=document.documentElement.scrollTop||document.body.scrollTop;
if((clientHeight+scorllTop)>lastTop){
return true;
}else{
return false;
}
}

javascript实现瀑布流效果(固定宽度)的更多相关文章

  1. javascript瀑布流效果

    javascript瀑布流效果 其实javascript瀑布流 前几年都已经很流行了(特别是美丽说,蘑菇街),最近看到网上有人问这个瀑布流效果,所以自己有空的时候就研究了下,其实也是研究别人的代码,研 ...

  2. 利用JS实现简单的瀑布流效果

    哈哈, 我又来啦, 在这一段时间里, 我简单的学习了一下javascript(JS), 虽然不是很懂啦, 但是我也简单的尝试着做了点小东西, 就比如现在流行的瀑布流效果, 经过我的努力终于成功的完成了 ...

  3. css基础之 图片瀑布流布局:用CSS+DIV等宽格子堆砌瀑布流效果 (一)

    <!doctype html> <html> <head> <meta charset="UTF-8"/> <title> ...

  4. 【前端】用jQuery实现瀑布流效果

    jQuery实现瀑布流效果 何为瀑布流: 瀑布流,又称瀑布流式布局.是比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部.最早 ...

  5. web页面和小程序页面实现瀑布流效果

    小程序实现瀑布流效果,和web页面差不多,都要经过以下步骤: 1).加载图片,获取图片的宽高度: 2).根据页面需要显示几列计算每列的宽度: 3).根据图片真实宽度和每列的宽度比,计算出图片需要显示的 ...

  6. jQuery淡入淡出瀑布流效果

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. RecylerView完美实现瀑布流效果

    RecylerView包含三种布局管理器,分别是LinearLayoutManager,GridLayoutManager,StaggeredGridLayoutManager,对应实现单行列表,多行 ...

  8. 使用JS实现图片展示瀑布流效果

    不知大家有没有发现,一般的图片展示网站都会使用瀑布流效果,所谓的瀑布流 就是网站内的图片不会一下子全缓存出来,而是等你滚动到一定的距离的时候, 下面的图片才会继续缓存,并且图片也是随机出现的,只是宽度 ...

  9. WPF下制作的简单瀑布流效果

    最近又在搞点小东西,美化界面的时候发现瀑布流效果比较不错.顺便就搬到了WPF,下面是界面 我对WEB前端不熟,JS和CSS怎么实现的,我没去研究过,这里就说下WPF的实现思路,相当简单. 1.最重要的 ...

随机推荐

  1. python2.7入门---模块(Module)

        来,这次我们就看下Python 模块(Module).它是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句.模块让你能够有逻辑地组织你的 Pytho ...

  2. 第6模块 web框架口述题

    状态码如200 OK,以3位数字和原因 成.数字中的 一位指定了响应 别,后两位无分 .响应 别有以下5种. 重定向:客户端像服务器端发送请求,服务器告诉客户端你去重定向(状态码302,响应头loca ...

  3. mono webreques https exception

    前几天在做一个使用URL通过WebRequest请求HTML页面的功能的时候遇到了点坑,程序在开发环境没有任何的问题,部署到linux mono上之后就跪了.代码如下: public static s ...

  4. 「学习记录」《数值分析》第三章计算实习题(Python语言)

    第三题暂缺,之后补充. import matplotlib.pyplot as plt import numpy as np import scipy.optimize as so import sy ...

  5. ES6 export,import报错

    问题描述: 现有两个文件: profile.js const firstName = 'Michael'; const lastName = 'Jackson'; const year = 2018; ...

  6. Sleuth+Zipkin+Log

    https://blog.csdn.net/sqzhao/article/details/70568637 https://blog.csdn.net/yejingtao703/article/det ...

  7. 在 C/C++ 中使用 TensorFlow 预训练好的模型—— 间接调用 Python 实现

    现在的深度学习框架一般都是基于 Python 来实现,构建.训练.保存和调用模型都可以很容易地在 Python 下完成.但有时候,我们在实际应用这些模型的时候可能需要在其他编程语言下进行,本文将通过 ...

  8. Cassandra 常见错误索引

    类型错误 类型错误调试的技巧 有时候,类型错误提示比较不友好,比如不知道哪个字段出错. 在php中可以用 //过滤几个数据进行操作,逐个检查,或者折半查找错误 $data = array_splice ...

  9. eclipse 创建Makefile工程生成多个执行文件

    1.创建Makefile工程 2.创建inc src Debug 目录 用于存放头文件源文件 3.编写Makefile 需要在有源文件的目标天剑Makefile文件,如下给出一个生成两个target的 ...

  10. 利用java中的BigInteger实现进制转换

    [原创] java中的进制BigInteger十分的强大,而且好用,他可以表示任意大的整数,同时还可以进行进制转换,十分的方便, 代码示例: package com.jiajia.demo_1; im ...