Heim Web-Frontend js-Tutorial 基于jQuery的一个扩展form序列化到json对象_jquery

基于jQuery的一个扩展form序列化到json对象_jquery

May 16, 2016 pm 06:14 PM
form 序列化

复制代码 代码如下:

$.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表单:
复制代码 代码如下:







对应到server端上的domain class是这样的:
复制代码 代码如下:

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字符串,就可以使用我下面的这个扩展
复制代码 代码如下:

/** @serializedParams looks like "prop1=value1&prop2=value2".  
Nested property like 'prop.subprop=value' is also supported **/
function paramString2obj (serializedParams) {

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 var tmpArray = Array();
tmpArray.push("obj");
for (var j = 0; 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 evalThem(properties[i]);
};
return obj;
}
$.fn.form2json = function(){
var serializedParams = this.serialize();
var obj = paramString2obj(serializedParams);
return JSON.stringify(obj);
}

使用起来大概像这个样子:
复制代码 代码如下:

var json = $("#testform").form2json();
alert(json);
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie können wir in Java eine Liste von Objekten mit FlexJson serialisieren? Wie können wir in Java eine Liste von Objekten mit FlexJson serialisieren? Sep 05, 2023 pm 11:09 PM

Flexjson ist eine schlanke Bibliothek zum Serialisieren und Deserialisieren von Java-Objekten in und aus dem JSON-Format. Wir können eine Liste von Objekten mit der Methode serialize() der Klasse JSONSerializer serialisieren. Diese Methode führt eine flache Serialisierung auf der Zielinstanz durch. Wir müssen eine Liste von Objekten vom Typ Liste als Parameter an die Methode serialize() übergeben. Syntax publicStringserialize(Objecttarget) Beispiel importflexjson.JSONSerializer;importjava.util.*;publicclassJsonSerial

Wie wirkt sich die Java-Serialisierung auf die Leistung aus? Wie wirkt sich die Java-Serialisierung auf die Leistung aus? Apr 16, 2024 pm 06:36 PM

Die Auswirkungen der Serialisierung auf die Java-Leistung: Der Serialisierungsprozess basiert auf Reflexion, was sich erheblich auf die Leistung auswirkt. Die Serialisierung erfordert die Erstellung eines Bytestroms zum Speichern von Objektdaten, was zu Speicherzuweisungs- und Verarbeitungskosten führt. Das Serialisieren großer Objekte verbraucht viel Speicher und Zeit. Serialisierte Objekte erhöhen die Belastung, wenn sie über das Netzwerk übertragen werden.

PHP-Datenverarbeitungskenntnisse: Verwendung der Serialisierungs- und Deserialisierungsfunktionen zur Implementierung der Datenserialisierung und -deserialisierung PHP-Datenverarbeitungskenntnisse: Verwendung der Serialisierungs- und Deserialisierungsfunktionen zur Implementierung der Datenserialisierung und -deserialisierung Jul 29, 2023 am 10:49 AM

PHP-Datenverarbeitungsfähigkeiten: Verwendung der Serialisierungs- und Deserialisierungsfunktionen zur Implementierung der Datenserialisierung und -deserialisierung. Serialisierung und Deserialisierung sind eine der am häufigsten verwendeten Datenverarbeitungsfähigkeiten in der Informatik. In PHP können wir die Funktionen serialize() und unserialize() verwenden, um Datenserialisierungs- und Deserialisierungsvorgänge zu implementieren. In diesem Artikel erhalten Sie eine detaillierte Einführung in die Verwendung dieser beiden Funktionen und stellen relevante Codebeispiele bereit. 1. Was ist Serialisierung und Deserialisierung in der Computerprogrammierung?

Wie führt die C++-Funktionsbibliothek die Serialisierung und Deserialisierung durch? Wie führt die C++-Funktionsbibliothek die Serialisierung und Deserialisierung durch? Apr 18, 2024 am 10:06 AM

Leitfaden zur Serialisierung und Deserialisierung der C++-Bibliothek Serialisierung: Erstellen eines Ausgabestreams und Konvertieren desselben in ein Archivformat. Objekte ins Archiv serialisieren. Deserialisierung: Erstellt einen Eingabestream und stellt ihn aus dem Archivformat wieder her. Deserialisieren Sie Objekte aus dem Archiv. Praxisbeispiel: Serialisierung: Erstellen eines Ausgabestreams. Erstellen Sie ein Archivobjekt. Erstellen Sie Objekte und serialisieren Sie sie im Archiv. Deserialisierung: Erstellen Sie einen Eingabestream. Erstellen Sie ein Archivobjekt. Erstellen Sie Objekte und deserialisieren Sie sie aus dem Archiv.

Wie serialisiere ich die Reihenfolge von Eigenschaften mithilfe der Jackson-Bibliothek in Java? Wie serialisiere ich die Reihenfolge von Eigenschaften mithilfe der Jackson-Bibliothek in Java? Aug 28, 2023 pm 12:45 PM

@JsonPropertyOrder ist eine Annotation, die auf Klassenebene verwendet wird. Als Attribut wird eine Liste von Feldern verwendet, die die Reihenfolge definiert, in der die Felder in der durch die JSON-Serialisierung des Objekts generierten Zeichenfolge erscheinen. In der Annotationsdeklaration enthaltene Eigenschaften können zuerst serialisiert werden (in der Reihenfolge, in der sie definiert sind), gefolgt von allen Eigenschaften, die nicht in der Definition enthalten sind. Syntax public@interfaceJsonPropertyOrder Beispiel importcom.fasterxml.jackson.core.*;importcom.fasterxml.jackson.databind.*;importcom.fasterxml.jac

Serialisierung und Deserialisierung von Schnittstellen und abstrakten Klassen in Java Serialisierung und Deserialisierung von Schnittstellen und abstrakten Klassen in Java May 02, 2024 am 08:33 AM

Schnittstellen können nicht direkt serialisiert werden, aber nur, wenn sie keine nicht-statischen, nicht-transienten Felder enthalten oder die Methoden writeObject() und readObject() überschreiben. Bestimmte Instanzen können durch konkrete Klassen implementiert werden, die die Schnittstelle implementieren oder überschreiben Sie die Methoden writeObject() und readObject.

Wie serialisiere ich eine Karte mithilfe der FlexJSON-Bibliothek in Java? Wie serialisiere ich eine Karte mithilfe der FlexJSON-Bibliothek in Java? Aug 26, 2023 pm 08:13 PM

Flexjson ist eine schlanke Bibliothek zum Serialisieren und Deserialisieren von Java-Objekten in und aus dem JSON-Format. Wir können eine Map auch mit der Methode serialize() der Klasse JSONSerializer serialisieren, die eine flache Serialisierung auf der Zielinstanz durchführt. Syntax publicStringserialize(Objecttarget) Beispiel importflexjson.JSONSerializer;importjava.util.*;publicclassJsonSerializeMapTest{ publ

Serialisierung und Deserialisierung von Golang-Funktionstypen Serialisierung und Deserialisierung von Golang-Funktionstypen Apr 29, 2024 am 08:15 AM

GoLang-Funktionstypen können über das Paket „encoding/gob“ serialisiert und deserialisiert werden. Serialisierung: Registrieren Sie einen benutzerdefinierten Typ und verwenden Sie gob.NewEncoder, um den Funktionstyp in ein Byte-Array zu codieren. Deserialisierung: Verwenden Sie gob.NewDecoder, um Funktionstypen aus Byte-Arrays zu deserialisieren.

See all articles