ExtJS使用Array向后台发送大量数据

我们在使用Extjs开发系统时,Extjs通过json从后台获取数据,同时保存数据时通过Post方式向服务器发送数据:

[javascript] view plaincopy
  1. Ext.Ajax.request({
  2. url : "/application/controller/field/AddHeaderGroup.action",
  3. method : 'POST',
  4. params : {
  5. displayName:nodeText,
  6. queryId : queryId
  7. },
  8. success : function(response, opts) {
  9. newNode.set("id",response.responseText.replace(/'/g,""));
  10. //console.log(newNode.get('id'));
  11. parentNode.appendChild(newNode);
  12. }
  13. });

有时要在编辑一个完整的grid之后点击“保存”时一次性保存整个grid的内容,Extjs可以通过store的getModifiedRecords和getRemovedRecords方法得到变化的和删除内容。这一般都会使用javascript的数组实现:先把一行数据push到数组中,再把一行数据的数组push到另一个数组中,发送到服务器。服务器端通过字符串解析还原数据内容。

这个过程中存在一个不足:数组中的字符串数据中如果有",",服务器端在解析数据时常得不到正确的结果---服务器端只能通过字符串的split(",")函数来分拆字符串。

那要怎么才能解决这个问题呢?

Extjs提供了数组编码:Ext.encode(Array)来解决这个问题。在把数组push到另一个数组中时,使用arr1.push(Ext.encode(arr2)),把编码后的数据push到另一个数组中(可以多层嵌套数组)。然后在服务器端解析每个使用Ext.encode()编码的数组时,都要使用:JSONArray.fromObject(groupList)把字符串还原成一个JSONArray。当然,每一个JSONArray.fromObject要对应一个Ext.encode()。这样就可以相对完美的解决Extjs批量保存数据时字符串中存在“,”造成的问题。

posted @ 2012-11-16 14:08  Kane_BJ  阅读(537)  评论(0编辑  收藏  举报