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


Posted in Javascript onAugust 13, 2013

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

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

对应的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中断执行的情况,简化了分页代码中大量的数组索引越界判断。

Javascript 相关文章推荐
腾讯与新浪的通过IP地址获取当前地理位置(省份)的接口
Jul 26 Javascript
file模式访问网页时iframe高度自适应解决方案
Jan 16 Javascript
jquery在IE、FF浏览器的差别详细探讨
Apr 28 Javascript
javascript设计模式之解释器模式详解
Jun 05 Javascript
jquery取子节点及当前节点属性值的方法
Sep 09 Javascript
js实现简单的联动菜单效果
Aug 19 Javascript
react-router实现按需加载
May 09 Javascript
jquery.masonry瀑布流效果
May 25 jQuery
JavaScript代码调试方法实例小结
Jan 05 Javascript
在vue中使用setInterval的方法示例
Apr 16 Javascript
JS中的模糊查询功能
Dec 08 Javascript
vue 表单输入框不支持focus及blur事件的解决方案
Nov 17 Vue.js
jQuery lazyLoad图片延迟加载插件的优化改造方法分享
Aug 13 #Javascript
js setTimeout 参数传递使用介绍
Aug 13 #Javascript
js setTimeout 常见问题小结
Aug 13 #Javascript
删除select中所有option选项jquery代码
Aug 12 #Javascript
js获取本机的外网/广域网ip地址完整源码
Aug 12 #Javascript
JavaScript解析URL参数示例代码
Aug 12 #Javascript
JS实现Enter键跳转及控件获得焦点
Aug 12 #Javascript
You might like
vBulletin HACK----关于排版的两个HACK
2006/10/09 PHP
PHP中怎样防止SQL注入分析
2014/10/23 PHP
laravel通过创建自定义artisan make命令来新建类文件详解
2017/08/17 PHP
ThinkPHP3.2框架自定义配置和加载用法示例
2018/06/14 PHP
jquery validation插件表单验证的一个例子
2010/03/03 Javascript
jQuery 技巧小结
2010/04/02 Javascript
js字符串完全替换函数分享
2014/12/03 Javascript
详解Bootstrap四种图片样式
2016/01/04 Javascript
JavaScript是如何实现继承的(六种方式)
2016/03/31 Javascript
React.js入门实例教程之创建hello world 的5种方式
2016/05/11 Javascript
JS事件添加和移出的兼容写法示例
2016/06/20 Javascript
Node.js的文件权限及读写flag详解
2016/10/11 Javascript
Javascript 函数的四种调用模式
2016/11/05 Javascript
js中字符型和数值型数字的互相转化方法(必看)
2017/04/25 Javascript
vue实现商城购物车功能
2017/11/27 Javascript
vue中使用codemirror的实例详解
2018/11/01 Javascript
vue+vuex+json-seiver实现数据展示+分页功能
2019/04/11 Javascript
node命令行工具之实现项目工程自动初始化的标准流程
2019/08/12 Javascript
原生js实现下拉选项卡
2019/11/27 Javascript
python写的一个squid访问日志分析的小程序
2014/09/17 Python
Python解析excel文件存入sqlite数据库的方法
2016/11/15 Python
numpy中的delete删除数组整行和整列的实例
2018/05/09 Python
Python 写入训练日志文件并控制台输出解析
2019/08/13 Python
pycharm工具连接mysql数据库失败问题
2020/04/01 Python
css背景图片的背景裁切、背景透明度、背景变换等效果运用
2012/12/24 HTML / CSS
Html5让容器充满屏幕高度或自适应剩余高度的布局实现
2020/05/14 HTML / CSS
西雅图电动自行车公司:Rad Power Bikes
2020/02/02 全球购物
医学生自荐信范文
2013/12/03 职场文书
商场端午节活动方案
2014/01/29 职场文书
中学生英语演讲稿
2014/04/26 职场文书
2014年社区教育工作总结
2014/12/02 职场文书
ktv服务员岗位职责
2015/02/09 职场文书
写给女朋友的检讨书
2015/05/06 职场文书
python实现简易名片管理系统
2021/04/11 Python
Python中使用subprocess库创建附加进程
2021/05/11 Python
nginx七层负载均衡配置详解
2022/07/15 Servers