3

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

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但不会foosome url.htm链接加载列的数据。

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

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

4

1 回答 1

3

这是绝对正确的问题!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();
        });
    }
});

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

在此处输入图像描述

对应的代码如下:

$("#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"});
});
于 2012-12-04T09:57:23.443 回答