1

我有两个 jqGrid。在第一个网格中,我选择一行,第二个网格根据第一个网格的 id 刷新数据。至少它应该是这样工作的。

//This is code from the second grid
postData: '{ lobId: ' + BudgetCore.getLobId() + ' }',

//Snippet from BudgetCore...
getLobId: function () {
    var row = jQuery(BudgetCore.GridTables.Lob).jqGrid('getGridParam', 'selrow');
    return row;
}

在 Chrome 中,我尝试调试函数 getLobid() 但它从未执行过。发送的 postData 请求:{ lobId:null }。

如果我将上面的代码更改为 '{ lobId: ' + 1 + ' }' 它可以工作,所以一定有什么错误导致这个函数无法执行。在 Chrome JS 控制台中执行 BudgetCore.getLobId() 工作正常。

4

1 回答 1

2

你应该使用

postData: {
    lobId: function () {
        return $(BudgetCore.GridTables.Lob).jqGrid('getGridParam', 'selrow');
    }
}

有关更多详细信息,请参阅答案

更新:如果你需要在JSON.stringify里面额外使用,serializeGridData那么你不能使用更简单的版本serializeGridData

serializeGridData: function (postData) { return return JSON.stringify(postData); }

取而代之的是,您应该使用我在答案serializeGridData中描述的更复杂的版本:

serializeGridData: function (postData) {
    var propertyName, propertyValue, dataToSend = {};
    for (propertyName in postData) {
        if (postData.hasOwnProperty(propertyName)) {
            propertyValue = postData[propertyName];
            if ($.isFunction(propertyValue)) {
                dataToSend[propertyName] = propertyValue(); // call the function
            } else {
                dataToSend[propertyName] = propertyValue;
            }
        }
    }
    return JSON.stringify(dataToSend);
}
于 2012-10-31T16:24:40.460 回答