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.最重要的 ...
随机推荐
- python2.7练习小例子(六)
6):题目:斐波那契数列. 程序分析:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0.1.1.2.3.5.8.13.21.34.……. ...
- 10-mongodb启动错误
1.error信息 python@ubuntu:~$ mongod --22T17:: I CONTROL [initandlisten] MongoDB starting : pid= port= ...
- 纯js生成QRCode
纯js,不依赖jquery,非常好用,废话不多说,直接上代码! <!DOCTYPE html> <html> <head> <meta charset=&qu ...
- jmeter插件下载
https://jmeter-plugins.org/wiki/Start/ 插件下载好后,将插件lib目录下的jar包放在jmeter安装目录下的lib里,插件ext目录下的jar包放在jmeter ...
- 「日常训练」「小专题·USACO」 Ski Course Design (1-4)
题目 以后补 分析 mmp这题把我写蠢哭了 我原来的思路是什么呢? 每轮找min/max,然后两个决策:升min/降max 像这样子dfs找最优,然后花式剪枝 但是一想不对啊,这才1-4,哪有那么复杂 ...
- Markdown常用的几种语法
在VScode上面写的,现将代码粘贴如下:(在VScode里运行下即可) # Markdown语法 # Ctrl + k v 打开侧边预览 ## 一.加粗斜体删除线 **这是要加粗的文字** *这是要 ...
- 扩展欧几里得 求ax+by == n的非负整数解个数
求解形如ax+by == n (a,b已知)的方程的非负整数解个数时,需要用到扩展欧几里得定理,先求出最小的x的值,然后通过处理剩下的区间长度即可得到答案. 放出模板: ll gcd(ll a, ll ...
- hibernate 批量插入
Session session = sessionFactoryUpLowLimit.openSession(); session.beginTransaction(); for(int i=0 ;i ...
- Hibernate 查询,返回结果设置到DTO
1:原生sql的查询,返回结果设置到DTO: Query query = sessionFactoryRtData.getCurrentSession().createSQLQuery(hql.toS ...
- Python 随笔01---列表
列表 1.取出列表中的元素方法?? 2.删除列表中的元素del.remove对比?? 3.linux 常用操作命令