AJAX的serializeArray()方法将表单元素以JSON字符串格式出入后台

来源:互联网 发布:网络攻击应急预案 编辑:程序博客网 时间:2024/05/29 16:38

今天遇到一个表单异步提交的问题,本来是想使用$(id).val()获取值当ajax参数传出,但遇到了明显问题表单数据量太大。这样写太烦了。

先发现了这个方法serialize():将表单内容序列化为字符串。

但它返回的是

a=1&b=2&c=3&d=4&e=5
这种格式。因为后台方法是Employee m = JSON.parseObject(employee, Employee.class);employee必须是json字符串格式这样转太麻烦。


之后就又找到了serializeArray()这个方法:序列化表单元素,返回 JSON 数据结构数据。

它返回的是

[   {name: 'firstname', value: 'Hello'},   {name: 'lastname', value: 'World'},  {name: 'alias'}, // 值为空]
没办法最后之后把他转成

var x=$("#frm").serializeArray();

var t="{";
        $.each(x, function(i, field){
              t+="\""+field.name+"\":\""+field.value+"\"";
              if(x.length-1!=i){t+=',';}
              alert(t);
        });
  t+="}";

t就是json格式的字符串了。。。

最后强调一下JSON.stringify(emp)这个方法用于从一个对象解析出字符串

是这样用的:

var emp = {};
        emp.employeeName=a;
        emp.employTime=b;

JSON.stringify(emp)

最后我只想说

作为一个java新手做项目真的太痛苦了!!!


对了强调一点serializeArray()必须有name属性才可以



阅读全文
0 0
原创粉丝点击