javascript - 在 jqGrid 中重新加载 dataurl 元素

标签 javascript jquery jqgrid

我有一个带有以下选项的简单网格:

jQuery("#mygrid").jqGrid({
   url: 'dataurl.htm',
   datatype: 'json',
   ajaxSelectOptions: { cache: false }
   ...
   colModel: [
    { name: 'foo', index: 'foo', width: 25, stype: 'select', searchoptions:{ sopt:       
     ['eq'], dataUrl: 'someurl.htm?columnName=foo'}}
    ]
});

但是,当我调用 $("#mygrid").trigger("reloadGrid");它只从 dataurl.htm 加载表的数据但它不会加载 foo 的数据来自 some url.htm 的专栏关联。

我已经在 SO 上阅读了几个这样的问题,建议有 ajaxSelectOptions: { cache: false }但这对我不起作用。

someurl.htm返回 <select> <option val=''>something</option></select>

最佳答案

这个问题绝对正确!当前的 jqGrid 实现只有 toggleToolbar 方法可以隐藏工具栏,但工具栏本身将被创建一次。因此工具栏的所有属性始终保持不变。

为了解决这个问题,我写了一个小的附加方法destroyFilterToolbar,它非常简单:

$.jgrid.extend({
    destroyFilterToolbar: function () {
        "use strict";
        return this.each(function () {
            if (!this.ftoolbar) {
                return;
            }
            this.triggerToolbar = null;
            this.clearToolbar = null;
            this.toggleToolbar = null;
            this.ftoolbar = false;
            $(this.grid.hDiv).find("table thead tr.ui-search-toolbar").remove();
        });
    }
});

The demo使用方法。可以在更改某些列的属性后重新创建搜索工具栏。在下面的代码中,可以从搜索工具栏更改某些文本的语言:

enter image description here

对应代码如下:

$("#recreateSearchingToolbar").change(function () {
    var language = $(this).val();

    // destroy searching toolbar
    $grid.jqGrid("destroyFilterToolbar");

    // set some searching options
    $grid.jqGrid("setColProp", "closed",
        language === "de" ?
                {searchoptions: {value: ":Beliebig;true:Ja;false:Nein"}} :
                {searchoptions: {value: ":Any;true:Yes;false:No"}});
    $grid.jqGrid("setColProp", "ship_via",
        language === "de" ?
                {searchoptions: {value: ":Beliebig;FE:FedEx;TN:TNT;IN:Intim"}} :
                {searchoptions: {value: ":Any;FE:FedEx;TN:TNT;IN:Intim"}});

    // create new searching toolbar with nes options
    $grid.jqGrid("filterToolbar", {stringResult: true, defaultSearch: "cn"});
});

关于javascript - 在 jqGrid 中重新加载 dataurl 元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13692177/

相关文章:

javascript - 110% 高度 vs 100% 滚动

javascript - 在 jquery 对话框中加载 html 页面

javascript - 如何更改select2中下拉列表的父容器

jquery - 在 jqGrid 中显示特定于字段的验证错误消息(服务器端验证)

javascript - 在jqgrid的编辑模式下如何使文本右对齐

javascript - 仅第一个添加值显示在 ng2-chart 折线图中

javascript - 如何将多个 html 表格导出到 excel?

javascript - 如何在多选下拉列表中输出所有选定选项的文本而不使用php javascript提交

jqgrid - 我的开发应用程序使用 JQgrid 4.6.0 版本,但当前的 jqgrid 不是免费的商业许可证

javascript - 在 while 循环中嵌入 Optgroup 的选择组