博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jqGrid的rowNum属性默认值、-1情况的介绍
阅读量:7095 次
发布时间:2019-06-28

本文共 1374 字,大约阅读时间需要 4 分钟。

最近做了一个用到了jqGrid的项目,在设置rowNum属性的时候遇到了坎坷...

rowNum属性的默认值为20,当你不设置时,每页最多只给你显示20条数据。

但是,当我们不想设置最大的数据条数时,我们还想显示全部数据怎么办,网上说设置为 -1 ,这时问题就出现了,这么设置在画面上会发现数据少了一条...坑啊...


为了解决这个问题,无奈只能开始调试...

最后发现问题发生点(jquery.jqGrid.src

var queryResults = query.select(),      recordsperpage = parseInt(ts.p.rowNum,10),      total = queryResults.length,      page = parseInt(ts.p.page,10),      totalpages = Math.ceil(total / recordsperpage),      retresult = {};      queryResults = queryResults.slice( (page-1)*recordsperpage , page*recordsperpage );      query = null;      cmtypes = null;      retresult[ts.p.localReader.total] = totalpages;      retresult[ts.p.localReader.page] = page;      retresult[ts.p.localReader.records] = total;      retresult[ts.p.localReader.root] = queryResults;      retresult[ts.p.localReader.userdata] = ts.p.userData;      queryResults = null;      return  retresult;

请重点看这段代码

queryResults = queryResults.slice( (page-1)*recordsperpage , page*recordsperpage );

当rowNum属性值为-1时,recordsperpage 会为 -1

此时执行.slice函数就有问题了,此时函数相当于queryResults.slice(0,-1),小伙伴们可以去查查.slice函数的API,大体意思就是

.slice(start,end) 返回区间为start 到 end位置的元素,请注意,如果是负数,则代表的意思是从数组尾部开始算起的元素

这回明白为什么数据会少了一条吧...

提供一种修改方式,添加一个条件判断吧


var queryResults = query.select(),      ...      if (recordsperpage != -1){      queryResults = queryResults.slice( (page-1)*recordsperpage , page*recordsperpage );      }      ...

转载地址:http://miaql.baihongyu.com/

你可能感兴趣的文章
Nginx 499错误
查看>>
Spring Boot实践--集成WebServices基础开发
查看>>
使用history.back(-1)的问题
查看>>
ubuntu 重设crontab -e的默认编辑器
查看>>
[unity3d]unity中C#委托的应用
查看>>
我的友情链接
查看>>
gson 处理泛型
查看>>
pssh 自动化运维
查看>>
主机上的vsphere ha 代理无法访问其它主机的部分管理网络地址
查看>>
网站在架构时要考虑的事情
查看>>
MySQL修改root密码的多种方法
查看>>
android中WebView小结
查看>>
7、yum 学习笔记
查看>>
gentoo-livedvd安装
查看>>
myphpadmin导入SQL文件大小的限制
查看>>
linux内核源码目录结构
查看>>
linux 文本命令之----tr
查看>>
Failed to execute goal 拒绝访问
查看>>
HttpsURLConnection
查看>>
搞懂深度学习到底需要哪些数学知识
查看>>