- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以,我有一个运行良好的 jqGrid 实现。我正在显示一些数据行,当添加新数据时——网格会相应地刷新。
但是,如果我尝试从网格中删除一行——它不会清除丢失的行!添加新行没问题,但删除会留下数据并导致网格显示出现错误。
如果我先调用“clearGridData”,我会看到数据已适当清理。但是,如果我调用 clearGridData——我会丢失我的选择/页面!
http://jsfiddle.net/yNw3C/1766/
var data = [[48803, "DSK1", "", "02200220", "OPEN"], [48769, "APPR", "", "77733337", "ENTERED"]];
$("#grid").jqGrid({
datatype: "local",
height: 250,
colNames: ['Inv No', 'Thingy', 'Blank', 'Number', 'Status'],
colModel: [{
name: 'id',
index: 'id',
width: 60,
sorttype: "int"},
{
name: 'thingy',
index: 'thingy',
width: 90,
sorttype: "date"},
{
name: 'blank',
index: 'blank',
width: 30},
{
name: 'number',
index: 'number',
width: 80,
sorttype: "float"},
{
name: 'status',
index: 'status',
width: 80,
sorttype: "float"}
],
caption: "Stack Overflow Example"
});
var names = ["id", "thingy", "blank", "number", "status"];
var mydata = [];
for (var i = 0; i < data.length; i++) {
mydata[i] = {};
for (var j = 0; j < data[i].length; j++) {
mydata[i][names[j]] = data[i][j];
}
}
for (var i = 0; i <= mydata.length; i++) {
$("#grid").jqGrid('addRowData', i + 1, mydata[i]);
}
$('#UpdateGridButton').click(function(){
mydata[0].status = "CLOSED";
delete mydata[1];
//If I add this -- I can refresh grid data properly, but I lose my selection.
//$('#grid').clearGridData();
$("#grid").jqGrid('setGridParam', { data: mydata});
$("#grid").trigger('reloadGrid', [{current: true}]);
});
jqGrid 隐式支持两全其美吗?还是我需要编写自定义逻辑?
最佳答案
抱歉,您目前使用 jqGrid 的方式有误。
首先网格的填充很重要。您目前使用addRowData
.据我所知,这是最古老但最慢的填充网格的方法。如果你使用 datatype: "local"
你应该使用 data: mydata
这允许直接用数据创建 jqGrid。
其他非常重要的选项是 gridview
和 rowNum
.您应该始终使用 gridview: true
以提高网格的性能(有关更多详细信息,请参见 the answer)。了解rowNum
的值(value)你应该知道 jqGrid 是为支持数据分页而设计的。如果是datatype: "local"
排序和分页将由 jqGrid 自己在本地实现。用于导航页面的寻呼机将通过使用 toppager: true
创建。选项或按用途 pager: "#pagerId"
. 即使您不创建任何寻呼机,本地寻呼机仍处于激活状态。默认值 rowNum
是 20。因此您当前的网格将仅显示前 20 行。唯一的异常(exception)是 addRowData
这强制在当前页面上临时添加行。重新加载后(例如通过更改排序间接加载)只会向用户显示前 20 行,并且用户将没有 GUI 来更改页面 (!!!???)。如果你想在一页上显示所有行,你应该使用 rowNum: 10000
例如。
下一个重要参数是autoencode: true
这意味着单元格的数据应该被解释为文本而不是 HTML 片段。如果你不使用 autoencode: true
您将无法显示包含 '<'
的文本, '>'
, '&'
等等。
我建议您另外使用 height: "auto"
如果您使用本地数据分页。它将删除为滚动条保留的正确大小的网格上的空白空间。您也可以使用 scrollOffset: 0
删除不需要的空间。
代码中的下一个重要错误是使用 setGridParam
与 data
范围。仅当网格之前为空或者您需要添加一些额外的行时,您才可以这样做。 setGridParam
存在主要是为了其他目的。它在内部使用 $.extend
(参见代码 here )。因此,您将扩展旧的数据包含新值而不是替换旧的 data
到新的。例如,您可以使用 getGridParam
获取对内部的引用data
参数:
var data = $("#grid").jqGrid("getGridParam", "data");
然后你可以修改数组data
使用 push
, pop
和 delete
.完全替换 data
你可以做到
var allParameters = $("#grid").jqGrid("getGridParam");
allParameters.data = newData; // or newData.slice(0)
之后您可以通过触发 "reloadGrid"
重新加载网格.
关于javascript - 使用比以前更少的行数据重新加载本地 jqGrid —— 没有看到行消失?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13922090/
如何获取特定 UTF-8 字符串的字节序列?我看到正则表达式引擎中的某些错误仅在某些边缘情况下才会触发,我想确切地知道它正在处理哪些数据。 最佳答案 也许 charToRaw ? > charToRa
考虑一个具有许多变量的 java 程序,其中一些是循环计数器,我希望看到这些变量随时间变化的值,而不是在代码中到处放置 print 语句。 为什么?我认为它可以帮助我轻松调试。 Example- in
有没有办法查看 JavaScript 正在创建的“线程”?例如,如果我有一个附加到 DOM 元素的事件处理程序,我假设 JavaScript 会隐式地创建一个新线程来在后台运行该代码?如果是这样,有没
我正在使用反射 API 来调用类运行时并调用其方法。但我看到 java.lang.reflect.InitationTargetException 异常。 我需要调用一个名为 - TestClass
考虑一个名为 t.cmd 的命令脚本,它只包含以下两行: @exit /b 123 @echo If you see this, THEN EXIT FAILED.. 因此,该脚本只是将脚本执行过程的
我最近一直在努力学习编程语言实用学第 3 版,以了解更多关于语言在底层如何工作的信息,并且通过查看由真正基本的 GCC 编译的 C 代码生成的程序集,我获得了很多进展.我开始对 C 系列的静态语言越来
最简单的制作方法是什么QWebView识别并正确加载网页上的 Flash? 最佳答案 似乎只需两行即可实现(当然,假设目标系统上安装了闪存): QWebSettings *settings = QWe
我想通过编程(使用VBA)访问其他人与我共享的日历。它们在我的Outlook中的“人民日历”下列出。我在网上搜索了此内容,所有建议所做的仅使我感到困惑。如何从“人的日历”中获取共享给我的所有日历的
使用MongoDB Compass,可以看到数据库用户或创建新用户吗? 最佳答案 香港专业教育学院在命令行上使用以下命令进行管理: mongo use (my database name) db.cr
我正在CentOS 7.4.1708(核心),Java(TM)SE运行时环境(内部版本1.8.0_152-b16)上运行eXist-db 3.6.1。我希望能够在person.xml中的最后一个记录之
我需要确认。 客户端 1 在事务内的表中插入行。 客户端 2 使用 SELECT 请求该表。如果在此客户端上隔离级别设置为 READ COMMITTED,您能否确认 SELECT 不会返回客户端 1
我刚刚安装了 python-dev: $ sudo apt-get install python-dev 这样我就可以开始使用 P4Python 了。但是当我尝试导入 P4 时,我得到: Traceb
我正在使用 msys 和 mingw 编译 libtorrent-rasterbar-0.16.16。./configure 运行良好,直到它进入 boost 库检查。我有 boost 1.51,我设
我在 GO 项目的 Travis CI 上有一个奇怪的行为。 [这里] 失败了,提示一个函数只接受 1 个参数并用 2 个参数调用。 src/finances-service/main.go:45:1
这个问题已经有答案了: What are enums and why are they useful? (27 个回答) 已关闭 4 年前。 作为 Java 初学者,我接触到了枚举,这让我对类型声明感
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
我正在使用 preactjs 创建我的应用程序。最重要的是,我正在使用剑道网格。在网格内,我想显示一个超链接。如果用户点击链接,它应该改变路线。为了呈现链接,我使用了 preact-router。 这
有没有办法只查看 Node.js 中的函数签名?我知道 fn.toString() 但不需要所有代码,只需要签名。 最佳答案 var source = fn.toString(); var signa
如何设置 vim 以查看我在 ubuntu 上安装的 ruby rvm。 rvm 已安装,ruby 从终端返回。 renshaw@renshaw-TravelMate-5740G:~$ ruby
我试图在我的 Android 应用程序中防止 OutOfMemoryError。我已经阅读了很多帖子,但我仍然无法解决。 该应用程序有后台 Activity ,所以我认为这是主要问题。 OutOfMe
我是一名优秀的程序员,十分优秀!