JS瀑布流实现方法实例分析


Posted in Javascript onDecember 19, 2016

本文实例分析了JS瀑布流实现方法。分享给大家供大家参考,具体如下:

描述:

1.每个图片宽度都一样,高度不一样

思路:

1.算出一共有几列(通过视窗总宽度/单个图片宽度得出)

2.根据一共几列*单个图片宽度,设置外围总宽度并水平居中(注:这个宽度应该是计算出来的,而不是定死,因为窗口大小会改变)

3.将第一行图片高度按顺序填充进数组

4.算出第一行图片里高度最短的那个,将第二行的第一张图片添加到其后(绝对定位),添加完第二行第一张,更新他的高度,然后重新计算最短,再开始之前的过程

5.鼠标在滑动滚轮时,继续加载新的图片(注:向上滚动不会加载,也不会一滚动就加载,而是向下滚动到一个临界值时才加载)

window.onload=function(){
  waterfall('main','pin');
  var dataInt={'data':[{'src':'1.jpg'},{'src':'2.jpg'},{'src':'3.jpg'},{'src':'4.jpg'}]};
  window.onscroll=function(){
    if(checkscrollside()){
      var oParent = document.getElementById('main');// 父级对象
      for(var i=0;i<dataInt.data.length;i++){
        var oPin=document.createElement('div'); //添加 元素节点
        oPin.className='pin'; //添加 类名 name属性
        oParent.appendChild(oPin); //添加 子节点
        var oBox=document.createElement('div');
        oBox.className='box';
        oPin.appendChild(oBox);
        var oImg=document.createElement('img');
        oImg.src='./images/'+dataInt.data[i].src;
        oBox.appendChild(oImg);
      }
      waterfall('main','pin');
    };
  }
}
/*
parend 父级id
pin 元素id
*/
function waterfall(parent,pin){
  var oParent=document.getElementById(parent);// 父级对象
  var aPin=getClassObj(oParent,pin);// 获取存储块框pin的数组aPin
  var iPinW=aPin[0].offsetWidth;// 一个块框pin的宽
  var num=Math.floor(document.documentElement.clientWidth/iPinW); //每行中能容纳的pin个数【窗口宽度除以一个块框宽度】
  oParent.style.cssText='width:'+iPinW*num+'px;margin:0 auto;';//设置父级居中样式:定宽+自动水平外边距
  var pinHArr=[];//用于存储 每列中的所有块框相加的高度。
  for(var i=0;i<aPin.length;i++){//遍历数组aPin的每个块框元素
    var pinH=aPin[i].offsetHeight;
    if(i<num){
      pinHArr[i]=pinH; //第一行中的num个块框pin 先添加进数组pinHArr
    }else{
      var minH=Math.min.apply(null,pinHArr);//数组pinHArr中的最小值minH
      var minHIndex=getminHIndex(pinHArr,minH);
      aPin[i].style.position='absolute';//设置绝对位移
      aPin[i].style.top=minH+'px';
      aPin[i].style.left=aPin[minHIndex].offsetLeft+'px';
      //数组 最小高元素的高 + 添加上的aPin[i]块框高
      pinHArr[minHIndex]+=aPin[i].offsetHeight;//更新添加了块框后的列高
    }
  }
}
/****
*通过父级和子元素的class类 获取该同类子元素的数组
*/
function getClassObj(parent,className){
  var obj=parent.getElementsByTagName('*');//获取 父级的所有子集
  var pinS=[];//创建一个数组 用于收集子元素
  for (var i=0;i<obj.length;i++) {//遍历子元素、判断类别、压入数组
    if (obj[i].className==className){
      pinS.push(obj[i]);
    }
  };
  return pinS;
}
/****
*获取 pin高度 最小值的索引index
*/
function getminHIndex(arr,minH){
  for(var i in arr){
    if(arr[i]==minH){
      return i;
    }
  }
}
function checkscrollside(){
  var oParent=document.getElementById('main');
  var aPin=getClassObj(oParent,'pin');
  var lastPinH=aPin[aPin.length-1].offsetTop+Math.floor(aPin[aPin.length-1].offsetHeight/2);//创建【触发添加块框函数waterfall()】的高度:最后一个块框的距离网页顶部+自身高的一半(实现未滚到底就开始加载)
  var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;//注意解决兼容性
  var documentH=document.documentElement.clientHeight;//页面高度
  return (lastPinH<scrollTop+documentH)?true:false;//到达指定高度后 返回true,触发waterfall()函数
}

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
网页前台通过js非法字符过滤代码(骂人的话等等)
May 26 Javascript
JS 屏蔽按键效果与改变按键效果的示例代码
Dec 24 Javascript
js判断文本框输入的内容是否为数字
Dec 23 Javascript
jQuery获取cookie值及删除cookie用法实例
Apr 15 Javascript
javascript类型系统_正则表达式RegExp类型详解
Jun 24 Javascript
Jq通过td获取同行其它列td的方法
Oct 05 Javascript
vue展示dicom文件医疗系统的实现代码
Aug 27 Javascript
vue基础之v-bind属性、class和style用法分析
Mar 11 Javascript
vue自动路由-单页面项目(非build时构建)
Apr 30 Javascript
ES6 Symbol数据类型的应用实例分析
Jun 26 Javascript
基于JavaScript实现表格隔行换色
May 08 Javascript
详解gantt甘特图可拖拽、编辑(vue、react都可用 highcharts)
Nov 27 Vue.js
移动端日期插件Mobiscroll.js使用详解
Dec 19 #Javascript
JavaScript闭包和范围实例详解
Dec 19 #Javascript
JS前端笔试题分析
Dec 19 #Javascript
利用vue实现模态框组件
Dec 19 #Javascript
JS中如何实现复选框全选功能
Dec 19 #Javascript
BootStrapValidator校验方式
Dec 19 #Javascript
详解js的延迟对象、跨域、模板引擎、弹出层、AJAX【附实例下载】
Dec 19 #Javascript
You might like
php生成局部唯一识别码LUID的代码
2012/10/06 PHP
解析php file_exists无效的解决办法
2013/06/26 PHP
PHP入门经历和学习过程分享
2014/04/11 PHP
phpmailer在服务器上不能正常发送邮件的解决办法
2014/07/08 PHP
php实现文章评论系统
2019/02/18 PHP
js获取当前月的第一天和最后一天的小例子
2013/11/18 Javascript
《JavaScript DOM 编程艺术》读书笔记之JavaScript 图片库
2015/01/09 Javascript
javascript基本包装类型介绍
2015/04/10 Javascript
javascript针对cookie的基本操作实例详解
2015/11/30 Javascript
AngularJs Injecting Services Into Controllers详解
2016/09/02 Javascript
Javascript 判断两个IP是否在同一网段实例代码
2016/11/28 Javascript
关于JavaScript中forEach和each用法浅析
2017/07/27 Javascript
JavaScript实现元素滚动条到达一定位置循环追加内容
2017/12/28 Javascript
jQuery中内容过滤器简单用法示例
2018/03/31 jQuery
vuejs实现ready函数加载完之后执行某个函数的方法
2018/08/31 Javascript
vue动态绑定class选中当前列表变色的方法示例
2018/12/19 Javascript
Postman如何实现参数化执行及断言处理
2020/07/28 Javascript
[01:37]全新的一集《真视界》——TI7总决赛
2017/09/21 DOTA
python对字典进行排序实例
2014/09/25 Python
Python写的一个定时重跑获取数据库数据
2016/12/28 Python
Python2.7环境Flask框架安装简明教程【已测试】
2018/07/13 Python
Random 在 Python 中的使用方法
2018/08/09 Python
django query模块
2019/04/20 Python
python实现爬虫抓取小说功能示例【抓取金庸小说】
2019/08/09 Python
Python2与Python3的区别详解
2020/02/09 Python
如何实现在jupyter notebook中播放视频(不停地展示图片)
2020/04/23 Python
Python类及获取对象属性方法解析
2020/06/15 Python
通过实例解析Python文件操作实现步骤
2020/09/21 Python
Net Remoting把服务器端激活两种模式
2014/01/22 面试题
幼儿园家长评语
2014/02/10 职场文书
教师群众路线心得体会
2014/11/04 职场文书
离婚起诉状范本
2015/05/19 职场文书
行政处罚告知书
2015/07/01 职场文书
导游词幽默开场白
2019/06/26 职场文书
pytorch 使用半精度模型部署的操作
2021/05/24 Python
CentOS7 minimal 最小化安装网络设置过程
2022/12/24 Servers