


Convertir les données du formulaire jquery en données json
Avec le développement du développement front-end, de plus en plus de sites Web et d'applications ont modifié la méthode de soumission de formulaires, passant des requêtes synchrones traditionnelles aux requêtes asynchrones. Dans ce processus, le front-end doit convertir les données du formulaire au format JSON, puis les envoyer au back-end pour traitement via une requête Ajax. Et cela nécessite de maîtriser certaines technologies connexes.
Lorsque nous utilisons jQuery pour faire fonctionner le formulaire, nous pouvons convertir les données du formulaire au format JSON via le code suivant :
var formData = $('form').serializeArray(); // 将表单序列化为键值对数组 var jsonData = {}; $.each(formData, function() { if (jsonData[this.name]) { // 如果json中已经有了该属性,则将其转换为数组 if (!jsonData[this.name].push) { jsonData[this.name] = [jsonData[this.name]]; } jsonData[this.name].push(this.value || ''); } else { jsonData[this.name] = this.value || ''; // 如果是第一次添加该属性,则直接加入json中 } });
Dans le code ci-dessus, nous utilisons d'abord la méthode serializeArray()
pour sérialiser le formulaire dans un tableau clé de paires de valeurs formData
. Ensuite, nous créons un objet vide jsonData
pour stocker les données JSON converties. Enfin, utilisez la méthode $.each()
pour parcourir le tableau de données du formulaire et ajoutez chaque paire clé-valeur à jsonData
. serializeArray()
方法将表单序列化为一个键值对数组formData
。接着我们创建一个空对象jsonData
来存储转换后的JSON数据。最后使用$.each()
方法遍历表单数据数组,并将每个键值对添加到jsonData
中。
需要注意的是,上述代码中使用了判断语句来处理表单中键值对重复的情况,遇到重复的属性名时将其转换为数组,并将新的值添加到数组中。
完整的例子如下:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>表单数据转JSON数据</title> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script> $(document).ready(function() { $('form').submit(function(event) { event.preventDefault(); // 阻止表单提交 var formData = $(this).serializeArray(); // 将表单序列化为键值对数组 var jsonData = {}; $.each(formData, function() { if (jsonData[this.name]) { // 如果json中已经有了该属性,则将其转换为数组 if (!jsonData[this.name].push) { jsonData[this.name] = [jsonData[this.name]]; } jsonData[this.name].push(this.value || ''); } else { jsonData[this.name] = this.value || ''; // 如果是第一次添加该属性,则直接加入json中 } }); console.log(jsonData); // 打印转换后的JSON数据,可以通过Ajax请求发送到后端进行处理 }); }); </script> </head> <body> <form> <label>姓名:</label> <input type="text" name="name" value="张三"><br> <label>性别:</label> <input type="radio" name="gender" value="male" checked>男 <input type="radio" name="gender" value="female">女<br> <label>爱好:</label> <input type="checkbox" name="hobby" value="reading" checked>阅读 <input type="checkbox" name="hobby" value="music">音乐 <input type="checkbox" name="hobby" value="travel">旅游<br> <button type="submit">提交</button> </form> </body> </html>
这样,我们就成功将表单数据转换为了JSON格式,并可以将其通过Ajax请求发送到后端。同时,需要注意的是,表单在提交之前需要阻止默认行为,这里我们使用了event.preventDefault()
event.preventDefault()
. 🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

L'article traite de l'utilisation Effecte dans React, un crochet pour gérer les effets secondaires comme la récupération des données et la manipulation DOM dans les composants fonctionnels. Il explique l'utilisation, les effets secondaires courants et le nettoyage pour éviter des problèmes comme les fuites de mémoire.

L'article explique l'algorithme de réconciliation de React, qui met à jour efficacement le DOM en comparant les arbres DOM virtuels. Il traite des avantages de la performance, des techniques d'optimisation et des impacts sur l'expérience utilisateur. Compte de charge: 159

Les fonctions d'ordre supérieur dans JavaScript améliorent la concision du code, la réutilisabilité, la modularité et les performances par abstraction, modèles communs et techniques d'optimisation.

L'article traite du curry dans JavaScript, une technique transformant les fonctions mulguments en séquences de fonctions à argument unique. Il explore la mise en œuvre du currying, des avantages tels que des applications partielles et des utilisations pratiques, améliorant le code

L'article discute de la connexion des composants React à Redux Store à l'aide de Connect (), expliquant MapStateToproprop, MapDispatchToprops et des impacts de performances.

L'article explique UseContext dans React, qui simplifie la gestion de l'État en évitant le forage des accessoires. Il traite des avantages tels que les améliorations centralisées de l'État et des performances grâce à des redevances réduites.

L'article discute de la prévention des comportements par défaut dans les gestionnaires d'événements à l'aide de la méthode empêchée dedEfault (), de ses avantages tels que une expérience utilisateur améliorée et des problèmes potentiels tels que les problèmes d'accessibilité.

L'article discute de la mise en œuvre de crochets personnalisés dans React, en se concentrant sur leur création, les meilleures pratiques, les avantages de la performance et les pièges communs à éviter.
