用jQuery的$()包装函数实现数组元素分页效果

文章简介:jQuery包装函数来实现数组元素分页效果的优势。

  用jQuery的$()包装函数来实现数组元素分页效果的优势

  最近一周在做中文站搜索礼品widget的需求,这个需求中有一个分页的功能;具体demo可以参见下图:

  

  (如上图,宽屏模式,1180下,每页3个offer)

  对应的js应用文件是同一个,页面中后面的offer数据已经埋好了,只是启用了css display:none样式把后面的offer元素隐藏了。现在要求对已存在的页面元素实现上下分页效果,也就是页面元素总集可以通过$(.class)获得,然后来实现分页功能。

  按照传统的一般做法,用jQuery可写成如下:

  var total=$(.class).length; //取得需要分页的元素的总个数

  var radio=3;//根据宽窄屏获得每页显示offer条数:

  var pageSize=parseInt(total/radio); //获得总页数;

  if(total % radio !=0){

  pageSize+=1;

  }

  var currentPage=1; //当前页为第一页

  //向前翻页的代码:

  $(.leftArrow,parentElem).bind("click",function(e){

  var index=currentPage-1;

  if(currentPage==1){

  return;

  }else{

  $(.class).css("display","none");

  var elemIndex=index*radio; //数组中起始要显示的元素的指针

  $(.class).eq(elemIndex).css("display","");

  $(.class).eq(elemIndex+1).css("display","");

  $(.class).eq(elemIndex+2).css("display","");

  //上面三句代码可用next()重写成

  //$(.class).eq(elemIndex).css("display","")

  // .next().css("display","")

  // .next()..css("display","");

  currentPage=index;

  }

  })

  //向后翻页的代码:

  $(.rightArrow,parentElem).bind("click",function(e){

  var index=currentPage+1;

  if(currentPage==pageSize){

  return;

  }else{

  $(.class).css("display","none");

  var elemIndex=index*radio; //数组中起始要显示的元素的指针

  $(.class).eq(elemIndex).css("display","");

  $(.class).eq(elemIndex+1).css("display","");

  $(.class).eq(elemIndex+2).css("display","");

  //上面三句代码可用next()重写成

  //$(.class).eq(elemIndex).css("display","")

  // .next().css("display","")

  // .next()..css("display","");

  currentPage=index;

  }

  })

  大家发现没有,在向后翻页的代码中,无论最后一页只有1条offer,2条offer,还是全部3条offer,我都用同样的代码,不做任何判断

  $(.class).eq(elemIndex).css(‘display’,”);

  $(.class).eq(elemIndex+1).css(‘display’,”);

  $(.class).eq(elemIndex+2).css(‘display’,”);

  这3条语句连续调用。

  也就是说,elemIndex有可能越界,即elemIndex>$(.class).length,即使在这样的情况下,$(.class).eq(elemIndex+1).css(‘display’,”)照样没有问题,浏览器不会报错,js照常执行,最终结果照样能完美展示。这要感谢jQuery的包装函数产生的juery对象,如果elemIndex>=$(.class).length,$(.class).eq(elemIndex+1)返回的是一个空jquery元素对象,虽然它没有对应到DOM中的元素,但它还是一个jQuery对象,因此调用.css()方法不会出错,虽然页面没有任何变化效果;

  通过这个例子,就能够理解为什么jQuey对不匹配的元素仍然返回jQuery Object,而不是null,这种思想对数组分页操作来说,提供了极大的便利性,因为避免了数组索引越界引起程序错误,导致js中断执行的情况,简化了分页代码中大量的数组索引越界判断。

时间: 2024-11-01 18:24:34

用jQuery的$()包装函数实现数组元素分页效果的相关文章

jQuery教程 $()包装函数来实现数组元素分页效果_jquery

最近一周在做中文站搜索礼品widget的需求,这个需求中有一个分页的功能:具体demo可以参见下图: 对应的js应用文件是同一个,页面中后面的offer数据已经埋好了,只是启用了css display:none样式把后面的offer元素隐藏了.现在要求对已存在的页面元素实现上下分页效果,也就是页面元素总集可以通过$(.class)获得,然后来实现分页功能. 按照传统的一般做法,用jQuery可写成如下: 复制代码 代码如下: var total=$(.class).length; //取得需要分

jquery中map函数遍历数组用法实例

  本文实例讲述了jquery中map函数遍历数组用法.分享给大家供大家参考.具体如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "

jquery中map函数遍历数组用法实例_jquery

本文实例讲述了jquery中map函数遍历数组用法.分享给大家供大家参考.具体如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <

jQuery实现仿腾讯视频列表分页效果的方法_jquery

本文实例讲述了jQuery实现仿腾讯视频列表分页效果的方法.分享给大家供大家参考.具体如下: 这里使用jQuery仿腾讯视频列表分页效果,无刷新分页特效,点击分页按钮,无刷新进入下一页内容列表. 运行效果截图如下: 具体代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&q

利用jQuery的动画函数animate实现豌豆发射效果_jquery

先来看看效果图 豌豆射手,草坪还有子弹都是现成的图片, 1. jQuery是库还是框架? jQuery可以说是现在最流行的一个js类库,而非框架. 之前在知乎上看到有人说了这样一句话: You call library. Framework calls you. 我深以为然,字面意思大概就是你可以无约束地使用类库,却需要在各种限制条件下使用一个框架. 我私以为,js 库指的是直接和document文档元素交互的一个API,你可以直接引用库,让它为你服务.而框架是偏向于架构的层次,你如果想要使用框

jQuery的animate函数实现图文切换动画效果

  animate()在jquery中作为一个方法,可用于创建动画效果,jquery中的animate()方法让那个页面增加了很好的视觉效果 在一些图片网站上我们可以看到在展示图片的时候,用鼠标轻轻滑上图片可以看到该图片的文字介绍信息,其实用jQuery的animate函数就可以实现这样一个动画过程. ? 1 2 3 4 5 6 7 8 <div class="wrap">    <img src="images/s1.jpg" alt="

jQuery的animate函数实现图文切换动画效果_jquery

在一些图片网站上我们可以看到在展示图片的时候,用鼠标轻轻滑上图片可以看到该图片的文字介绍信息,其实用jQuery的animate函数就可以实现这样一个动画过程. <div class="wrap"> <img src="images/s1.jpg" alt="photo" /> <div class="cover"> <h3>强震摧毁加勒比海小国海地</h3> <

PHP中数组元素升序、降序及重新排序的函数

在PHP数组学习摘录部分了解到最基本的PHP数组的建立和数组元素的显示.需要深入学习下PHP数组的相关操作.首先接触的就是数组元素的升序.降序的排序问题. 1,快速创建数组的函数range() 比如range()函数可以快速创建从1到9的数字数组: <?php $numbers=range(1,9);echo $numbers[1];?> 当然,使用range(9,1)则创建了9到1的数字数组.同时,range()还可以创建从a到z 的字符数组: <?php $numbers=range

解析PHP中数组元素升序、降序以及重新排序的函数_php技巧

1,快速创建数组的函数range()比如range()函数可以快速创建从1到9的数字数组: 复制代码 代码如下: <?php $numbers=range(1,9);echo $numbers[1];?> 当然,使用range(9,1)则创建了9到1的数字数组.同时,range()还可以创建从a到z 的字符数组: 复制代码 代码如下: <?php $numbers=range(a,z);foreach ($numbers as $mychrs)    echo $mychrs."