Arrays 来自本地对象数组的JQGrid数据

Arrays 来自本地对象数组的JQGrid数据,arrays,object,jqgrid,local,Arrays,Object,Jqgrid,Local,我根据用户的选择创建一个本地对象集合。动态数组应加载到jqGrid。动态创建阵列后,我尝试重新加载,但什么也没发生。这是密码- $(document).ready(function () { var arrobj = []; var JSONString = []; //[{"DOId":"0","DONo":"Please select","DealerCode":"0","Week":"0","Item":"0","Qty":"1

我根据用户的选择创建一个本地对象集合。动态数组应加载到jqGrid。动态创建阵列后,我尝试重新加载,但什么也没发生。这是密码-

$(document).ready(function () {

         var arrobj = [];           

         var JSONString = []; //[{"DOId":"0","DONo":"Please select","DealerCode":"0","Week":"0","Item":"0","Qty":"11","Date":"11"}]

         $("#<%=btnAdd.ClientID%>").click(function () {
             //Get values
             //Date
             var dlDt = $("#<%=tbRchngDt.ClientID%>").val();
             //Qty
             var dlQty = $("#<%=tbQty.ClientID%>").val();
             //item
             var dlItem = $("#<%=ddlItem.ClientID%>").val();
             //DO No
             var dlDOId = $("#<%=ddlDO.ClientID%>").val();
             var dlDO = $("#<%=ddlDO.ClientID%> option:selected").text();
             //Week
             var dlWeek = $("#<%=ddlWeek.ClientID%>").val();
             //Dealer
             var dlDealer = $("#<%=ddlDealer.ClientID%>").val();

             DistributionDtl = new Object();
             DistributionDtl.DOId = dlDOId;
             DistributionDtl.DONo = dlDO;
             DistributionDtl.DealerCode = dlDealer;
             DistributionDtl.Week = dlWeek;
             DistributionDtl.Item = dlItem;
             DistributionDtl.Qty = dlQty;
             DistributionDtl.Date = dlDt;


             //alert(DistributionDtl);
             arrobj.push(DistributionDtl);
             JSONString = JSON.stringify(arrobj);
             //alert(JSONString);
             $("#list").jqGrid('setGridParam',
             { datatype: "local",
                 data: JSONString
             }).trigger("reloadGrid");

         });
         jQuery("#list").jqGrid({ data: JSONString,
             datatype: "local",
             height: 150,
             width: 600,
             rowNum: 10,
             rowList: [10, 20, 30],
             colNames: ['DOID', 'Item', 'Qty', 'Date'],
             colModel: [{ name: 'DOId', index: 'DOId', width: 60, sorttype: "int" },
                                { name: 'Item', index: 'Item', width: 120 },
                                 { name: 'Qty', index: 'Qty', width: 80 },
                                  { name: 'Date', index: 'Date', width: 120}],
             pager: "#pager",
             viewrecords: true,
             caption: "Contacts"
         });

     });

应使用以下任一方法将本地数据添加到jqgrid:

addJSONData-数据为json addRowData—逐行添加,然后触发重新加载网格以重新计算分页—数据应该是javascript对象
可以找到文档。编辑:根据文档,您可以直接在数据参数中设置本地数据,但它应该是一个数组,而不是json字符串,并且您的问题中没有JSONString的内容,因此问题可能来自于此。

I小挑剔,但值得一试的是,可能不需要在触发器行中将GridParam设置为构建网格时已设置的值。因此可以使用$list.jqGrid.triggerreloadGrid;thnx,但仍然不工作您是否看到网格在Firebug/Chrome中请求新数据?你能用一些静态数据设置一个完全不同的文本数组来测试你的网格是否在更改中提取任何数据吗?是的,如果我使用与静态文本相同的数据,它就可以工作。hanks。addRowData正在运行。我正在做的是jQuerylist.addRowDataDistributionDtl.DOId,DistributionDtl;有一个问题。以这种方式添加数据后,当我选择一行时,它会选择第一行,如果我尝试删除一条记录,因为Oleg显示所有行都已删除,那么现在工作正常。不知何故,所有行的Rowid都是相同的。这就是我遇到这个问题的原因。现在我已经将addrowdata更改为jQuerylist.addRowDataslNo,DistributionDtl,last;当您使用addrowdata时,在添加所有行之后,请不要忘记使用“.trigger'reloadGrid”,因为例如,如果您的网格显示10行/页,而您添加了11行,则网格在重新加载之前不会正确分页,因为它没有完成分页计算。