jQuery一直没系统的学,只知道是js库,封装了好多js函数,方便了开发。以前做过一个原生的图片网站瀑布流效果,超级麻烦,这次用了jQuery方法,瞬间代码浓缩了,只有56行js代码。神奇的让我来把其中的几个函数具体记录一下。

  首先,在WebStorm中新建一个工程,导入jquery库和几张img放在img文件夹下,新建html和css文件,用来搭建基本的网页结构。我们设定图片的宽度固定,高度不定,绝对定位,左浮动。这里就不细说了。我们主要讲jquery部分的知识。

  这里我们讲一下我们要实现的效果,瀑布流效果就是视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据并附加至当前尾部。除第一行元素外,其他的元素要按照之前的排列中高度最低的下面。一次循环。当屏幕滚动的时候,判断加载条件,动态加载。

  开始吧。

  (1)HTML文档整体加载,监听window的load事件.

$(document).ready(function(){
$(window).on("load",function(){ };
};

  (2).判断图片的位置。即当图片多于一行时,剩下的图片应该摆放在哪里。

function imgLocation(){
//用jquery获取所有的box
var box = $(".box");
//box的宽度
var boxWidth = box.eq(0).width();
//每行共有几个box
var num = Math.floor($(window).width()/boxWidth);
//存放box的boxHeight
var boxArr = [];
//each方法遍历box,当只有一行的时候记录boxHeight,多于一行则找出minBoxHeight,并设置样式。
box.each(function(index,value){
var boxHeight = box.eq(index).height();
if(index<num){
boxArr[index] = boxHeight;
}else{
var minBoxHeight = Math.min.apply(null,boxArr);
var minBoxIndex = $.inArray(minBoxHeight,boxArr);
$(value).css({
"position":"absolute",
"top":minBoxHeight,
"left":box.eq(minBoxIndex).position().left
});
//动态变化minBoxIndex
boxArr[minBoxIndex] += box.eq(index).height();
}
});
}

  (3).监听屏幕的滚动事件。当屏幕的高度大于最后一张图片的高度的1/2时,加载资源。

function scrollside(){
var box = $(".box");
var lastboxHeight = box.last().get(0).offsetTop+Math.floor(box.last().height()/2);
var documentHeight=$(document).width();
var scrollHeight=$(window).scrollTop();
return (lastboxHeight<scrollHeight+documentHeight)?true:false;
}

  (4).监听屏幕的函数写好以后,我们先在load加载事件中本地写一个JSON数据,传递图片资源。

    即:var dataImg={"data":[{"src":"1.jpg"},{"src":"2.jpg"},{"src":"3.jpg"},{"src":"4.jpg"},{"src":"5.jpg"}]};

  (5).实现window的onscroll事件。当满足(3)中滚动的条件时,我们动态的创建box,然后appendTo相应的父容器中

window.onscroll=function(){
if(scrollside()){
//each()方法遍历数据加载进来
$.each(dataImg.data,function(index,value){
var box = $("<div>").addClass("box").appendTo($("#container"));
var content = $("<div>").addClass("content").appendTo(box);
console.log("./img/"+$(value).attr("src"));
$("<img>").attr("src","./img/"+$(value).attr("src")).appendTo(content);
});
imgLocation();
}
};

  至此,用jQuery实现照片瀑布流的方法已经实现了。在整个过程中,我主要学到了

  •   each()方法遍历数组,
  • eq()
  •   Math.min.apply()找出数组中最小数,
  •   jquery.inarray(value,array) 确定第一个参数在数组中的位置,
  •   $(value).css用jquery设置css样式,
  •   动态添加HTML文档节点,并从JSON数据中获取相应的属性。

工程文件放在网盘了,朋友有需要的话可以去下载。jquery实现瀑布流效果。链接: http://pan.baidu.com/s/1dEEmr5n 密码: cjic

用jQuery实现瀑布流效果学习笔记的更多相关文章

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

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

  2. jquery实现瀑布流效果

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

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

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

  4. 用JavaScript和jQuery实现瀑布流

    ▓▓▓▓▓▓ 大致介绍 在慕课网上学习了用原生js和jQuery实现瀑布流,在这里做个笔记 ▓▓▓▓▓▓ 用JavaScript实现 基本结构: <div id="main" ...

  5. jQuery实现瀑布流

    瀑布流布局多用于加载图片,或者图片配上文字.视觉表现为参差不齐的多栏布局.随着页面滚动条向下滚动,还会不断加载数据块并附加至当前尾部.本文就来利用jQuery实现一个图片瀑布流的效果. 1.布局. 首 ...

  6. Jquery简单瀑布流代码示例

    最近很多网站都采用瀑布流风格设计,感觉挺有个性的,比较合适做图片类型的网站,没事仿开心网做一个瀑布流示例. 需要用到Jquery,jquery.masonry.min.js <!DOCTYPE ...

  7. jquery版瀑布流

    一个月前用jquery实现了瀑布流效果,看着当时的代码有点难过……今天抽时间稍微修改了一下.额,现在看起来不是那么难受了,就来和大家分享一下.废话不多说,开始正题~ 一.演示效果 二.html代码 & ...

  8. 网友微笑分享原创Jquery实现瀑布流特效

    首先非常感谢网友微笑的无私分享,此Jquery特效是一款非常流行和实用的瀑布流布局,核心代码只有几十行,是我见过代码量最少的瀑布流布局,非常适合网友们学习哦,希望大家好好看一下这个Jquery特效的原 ...

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

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

随机推荐

  1. 【leetcode】com/problems/surrounded-regions/

    dfs 栈溢出,bfs超时,用dfs非递归就不溢出了,前后写了1一个星期class node { int i; int j; public node(int i1,int j1) { i=i1; j= ...

  2. asp json

    <script language="JScript" runat="Server">function toObject(json) {    eva ...

  3. matches()方法

    java.lang包中的String类和java.util.regex包中的Pattern,Matcher类中都有matches()方法,都与正则表达式有关.下面我分别举例:(字符串:"ab ...

  4. CCHttpClient发起https请求

    游戏中用http post请求和服务器交互,随便一抓包就暴露了提交的数据,太不靠谱,决定对游戏中一些敏感数据使用https协议,HTTPS协议是由SSL+HTTP协议构建的可进行加密传输.身份认证的网 ...

  5. 去除android ImageView “[Accessibility] Missing contentDescription attribute on image” warning

    1.在有警告的xml上选择Graphical Layout: 2.查看右上角的被涂鸦的地方,然后点击: 3.出现: 4.点击”Ignore Type“或者是“Disable Issue Type”(不 ...

  6. hdu 4911 Inversion(归并排序求逆序对数)2014多校训练第5场

    Inversion                                                                             Time Limit: 20 ...

  7. Eclipse启动 报错[Failed to load the JNI shared library jvm.dll

    准备要做java服务器,在安装开发环境时,启动Eclipse报错[Failed to load the JNI shared library jvm.dll] 研究了下,造成错误的原因是由于eclip ...

  8. linux 管道--转

    linux 管道 管道是Linux中很重要的一种通信方式,是把一个程序的输出直接连接到另一个程序的输入,常说的管道多是指无名管道,无名管道只能用于具有亲缘关系的进程之间,这是它与有名管道的最大区别. ...

  9. 深入分析 Java I/O 的工作机制--转载

    Java 的 I/O 类库的基本架构 I/O 问题是任何编程语言都无法回避的问题,可以说 I/O 问题是整个人机交互的核心问题,因为 I/O 是机器获取和交换信息的主要渠道.在当今这个数据大爆炸时代, ...

  10. SDL Game Development InputHandler类的一处bug

    个人十分推荐SDL Game Development 这本书,它并不是死抠SDL的api,而是一步步带着我们如何对一个游戏进行构架. 虽然我没用过游戏引擎,也基本不会写游戏,但是我认为这本书本身就是在 ...