javascript实现瀑布流效果(固定宽度)
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实现瀑布流效果(固定宽度)的更多相关文章
- javascript瀑布流效果
javascript瀑布流效果 其实javascript瀑布流 前几年都已经很流行了(特别是美丽说,蘑菇街),最近看到网上有人问这个瀑布流效果,所以自己有空的时候就研究了下,其实也是研究别人的代码,研 ...
- 利用JS实现简单的瀑布流效果
哈哈, 我又来啦, 在这一段时间里, 我简单的学习了一下javascript(JS), 虽然不是很懂啦, 但是我也简单的尝试着做了点小东西, 就比如现在流行的瀑布流效果, 经过我的努力终于成功的完成了 ...
- css基础之 图片瀑布流布局:用CSS+DIV等宽格子堆砌瀑布流效果 (一)
<!doctype html> <html> <head> <meta charset="UTF-8"/> <title> ...
- 【前端】用jQuery实现瀑布流效果
jQuery实现瀑布流效果 何为瀑布流: 瀑布流,又称瀑布流式布局.是比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部.最早 ...
- web页面和小程序页面实现瀑布流效果
小程序实现瀑布流效果,和web页面差不多,都要经过以下步骤: 1).加载图片,获取图片的宽高度: 2).根据页面需要显示几列计算每列的宽度: 3).根据图片真实宽度和每列的宽度比,计算出图片需要显示的 ...
- jQuery淡入淡出瀑布流效果
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- RecylerView完美实现瀑布流效果
RecylerView包含三种布局管理器,分别是LinearLayoutManager,GridLayoutManager,StaggeredGridLayoutManager,对应实现单行列表,多行 ...
- 使用JS实现图片展示瀑布流效果
不知大家有没有发现,一般的图片展示网站都会使用瀑布流效果,所谓的瀑布流 就是网站内的图片不会一下子全缓存出来,而是等你滚动到一定的距离的时候, 下面的图片才会继续缓存,并且图片也是随机出现的,只是宽度 ...
- WPF下制作的简单瀑布流效果
最近又在搞点小东西,美化界面的时候发现瀑布流效果比较不错.顺便就搬到了WPF,下面是界面 我对WEB前端不熟,JS和CSS怎么实现的,我没去研究过,这里就说下WPF的实现思路,相当简单. 1.最重要的 ...
随机推荐
- Linux下启动Oracle服务和监听程序步骤
Linux下启动Oracle服务和监听程序启动和关闭步骤整理如下: 1.安装oracle: 2.创建oracle系统用户: 3./home/oracle下面的.bash_profile添加几个环境变量 ...
- 2,理解JVM
一.内存管理: 1,内存结构: 栈和堆区别,栈是连续内存区,一般是2M单位,堆是不连续的链表.受限于虚拟内存,new时分配 PC寄存器.java栈.堆.方法区.本地方法区.运行常量池 java ...
- python 字典(dict)按键和值排序
python 字典(dict)的特点就是无序的,按照键(key)来提取相应值(value),如果我们需要字典按值排序的话,那可以用下面的方法来进行: 1 下面的是按照value的值从大到小的顺序来排序 ...
- iOS笔记058 - IOS之多线程
IOS开发中多线程 主线程 一个iOS程序运行后,默认会开启1条线程,称为"主线程"或"UI线程" 作用 显示和刷新界面 处理UI事件(点击.滚动.拖拽等) 注 ...
- Freemarker 的 Shiro 标签使用详解
一.引入依赖(已解决版本冲突) <!-- shiro-freemarker-tags start --> <dependency> <groupId>net.min ...
- virsh查看迁移信息的两个命令
virsh qemu-monitor-command uuid --hmp info migrate, 能看到迁移所设置的相关参数,和进度相关信息: virsh domjobinfo uuid命令, ...
- 在Android Studio中创建(或添加)第一个Hello World应用程序
下面我们将使用Android Studio创建第一个简单的Hello World应用程序. 1.打开Android Studio,加载画面如下图所示: 2.选择”Start a new Andro ...
- C++STL——vector
一.相关定义 vector 数组 随机访问迭代器 快速随机访问元素 尾部进行快速随机地插入和删除操作 特征: 能够存放任意类型: 访问vector中的任意元素或从末尾添加元素都可以在常量级时间复杂度内 ...
- B - 寻找M
B - 寻找M Time Limit: 1000/1000MS (C++/Others) Memory Limit: 65536/65536KB (C++/Others) Problem Descri ...
- PokeCats开发者日志(二)
现在是PokeCats游戏开发的第四天的上午,来记录一下昨天做的事情吧. day3 day3主要是添加音效和优化界面,本以为添加个音效1~2个小时就够了吧,没想到贼不顺,弄了一个下午才搞好. ...