jQuery扩展 form序列化到json对象
来源:互联网 发布:rfcn网络 编辑:程序博客网 时间:2024/05/09 04:15
jQuery没有直接支持form到json的序列化方法,目前网上有一个实现是这样的
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
$.fn.serializeObject =
function
() {
var
o = {};
var
a =
this
.serializeArray();
$.each(a,
function
() {
if
(o[
this
.name]) {
if
(!o[
this
.name].push) {
o[
this
.name] = [ o[
this
.name] ];
}
o[
this
.name].push(
this
.value ||
''
);
}
else
{
o[
this
.name] =
this
.value ||
''
;
}
});
return
o;
}
这个function对于普通的对象转换是足够的,但是如果出现对象内部又包含子对象的情形就不能支持了。
例如我有这样的一个form表单:
1
2
3
4
5
<
form
id="testform">
<
input
type="text" name="name" value="dummyName" id="name">
<
input
type="text" name="category.id" value="categoryId" id="name">
<
input
type="text" name="category.name" value="categoryName" id="name">
</
form
>
对应到server端上的domain class是这样的:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
public
class
DummyProduct {
private
DummyCategory category;
private
String name;
public
DummyCategory getCategory() {
return
category;
}
public
void
setCategory(DummyCategory category) {
this
.category = category;
}
public
String getName() {
return
name;
}
public
void
setName(String name) {
this
.name = name;
}
}
public
class
DummyCategory {
private
String id;
private
String name;
public
String getId() {
return
id;
}
public
void
setId(String id) {
this
.id = id;
}
public
String getName() {
return
name;
}
public
void
setName(String name) {
this
.name = name;
}
}
如果想把表单数据序列化成跟server端domain class匹配的json字符串,就可以使用我下面的这个扩展
1
/** @serializedParams looks like
"prop1=value1&prop2=value2"
.
1
Nested property like
'prop.subprop=value'
is also supported **/
1
function
paramString2obj (serializedParams) {
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
var
obj={};
function
evalThem (str) {
var
attributeName = str.split(
"="
)[0];
var
attributeValue = str.split(
"="
)[1];
if
(!attributeValue){
return
;
}
var
array = attributeName.split(
"."
);
for
(
var
i = 1; i < array.length; i++) {
var
tmpArray = Array();
tmpArray.push(
"obj"
);
for
(
var
j = 0; j < i; j++) {
tmpArray.push(array[j]);
};
var
evalString = tmpArray.join(
"."
);
// alert(evalString);
if
(!eval(evalString)){
eval(evalString+
"={};"
);
}
};
eval(
"obj."
+attributeName+
"='"
+attributeValue+
"';"
);
};
var
properties = serializedParams.split(
"&"
);
for
(
var
i = 0; i < properties.length; i++) {
evalThem(properties[i]);
};
return
obj;
}
$.fn.form2json =
function
(){
var
serializedParams =
this
.serialize();
var
obj = paramString2obj(serializedParams);
return
JSON.stringify(obj);
}
使用起来大概像这个样子:
1
2
var
json = $(
"#testform"
).form2json();
alert(json);
0 0
- jQuery扩展 form序列化到json对象
- jquery form序列化转换为json对象
- JQuery加载Json对象到form
- jQuery serializeObject 序列化form表单Json对象 jQuery.extend()合并对象
- jQuery serializeObject 序列化 form 表单 Json 对象 jQuery.extend() 合并对象
- jquery 将form中的元素序列化成对象;序列化对象填充到指定input
- jQuery 扩展,将复杂form表单转成json对象serializeJson
- jQuery序列化表单为JSON对象
- jQuery序列化表单为JSON对象
- jQuery序列化表单为JSON对象
- jquery将表单序列化json对象
- jquery form 序列化
- XStream 序列化对象到JSON
- jquery form表单序列化成json格式
- jquery序列化form表单对象教程网址
- form表单序列化JSON
- serializeObject——序列化Form表单到一个对象
- jquery form表单序列化为对象
- JAVA中文字符编码问题详解(1)(转)
- windows下修改hosts后,出现:foxmail错误:请求的名称有效,但是找不到请求的类型的数据
- Summation of Series
- C# Attributes 笔记
- 对线性回归、逻辑回归、各种回归的概念学习
- jQuery扩展 form序列化到json对象
- 最容易出现的安全问题
- robotium使用笔记
- 骨头动画解析
- 随着预装Win8电脑大量涌向市场,UEFI+GPT这一标准组合受到了更大范围的关注。UEFI+GPT无疑是未来的发展趋势,所以我们有必要先来了解一下用于引导Windows的GPT分区结构的磁盘中一些特
- Word中,在原文基础上为所有汉字前后增加相同内容
- Oracle 查看用户相关信息
- sqlite基本操作
- javascript ,检测属性