Bonjour,
Je sais que jquery peut retourner des données au format json.
Mais peut-on en envoyer dans ce format (comme le permet prototype) ? La célèbre fonction $get(), accepte t-elle en paramètre une chaine json ?
Merci d'avance.
Version imprimable
Bonjour,
Je sais que jquery peut retourner des données au format json.
Mais peut-on en envoyer dans ce format (comme le permet prototype) ? La célèbre fonction $get(), accepte t-elle en paramètre une chaine json ?
Merci d'avance.
regarde au niveau du dataType...Code:
1
2
3
4
5
6
7 $.ajax({ url: url, data: data, success: success, dataType: 'json' });
Techniquement, ta question n'a pas vraiment de sens : les seules données qui peuvent transiter entre le client et le serveur (donc en particulier dans une requête AJAX) sont des données textuelles.Citation:
Peut-on envoyer du json au serveur
Le fait de "recevoir" du JSON signifie juste que le serveur a renvoyé une chaine correctement formatée puis que jQuery (ou toute autre librairie) l'a évaluée et donc transformé en objet JSON.
Seulement, jQuery n'intervient pas coté serveur et est donc incapable de faire interpréter ce qu'il envoie comme étant du JSON, en revanche, il "sait" formater une chaine pour que le langage serveur puisse l'évaluer à son tour comme du JSON ;)
Bonjour,
:nono: dataType c'est le type des données que tu attends en retour du serveur, pas ce que tu envoies ;)
Ceci dit, c'est tout à fait possible et je vous avouerais ne passer plus que par JSON pour communiquer avec le serveur...
Un exemple de code (côté client):
Côté serveur :Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14 var json = { name: "Hello", text: "World" }; $.ajax({ // $.get n'est qu'une abbréviation de $.ajax avec des options de bases url: "URL.com", type: "GET", data: json, success: function(data, xhr, status) { // Si réussite } });
Code:
1
2
3 $name = $_GET["name"]; // Hello $text = $_GET["value"]; // World
Pour le datatype, c'est qu'il me semblait aussi.
Ce qui me fait douter qu'on puisse est que sur le site suivant
j'ai vu çaCitation:Or en json, je ne crois pas qu'on écrit un tableau comme ça. On écrit pasCode:$.get("test.php", { 'choices[]': ["Jon", "Susan"]} );
maisCode:choices[]
sans les crochets. Bref, on dirait que le format attendu par $.get() n'est pas json.Code:choices
De toute façon, la semaine prochaine, je ferai un essai d'envoi d'un gros objet en json et je vous dirais. ;)
:roll:
Vous avez lu mon post? C'est tout à fait possible d'envoyer du JSON en AJAX.
$.post, $.get $.getJSON se basent tous sur $.ajax. Ce sont des wrappers qui permettent de réduire la taille du code car ses fonctions embarquent un paramétrage de base.
Dans tous les cas, ce que vous cherchez à faire est réalisable (cf mon post précédent).
+
Arnaud, tu n'envoies pas réellement du JSON, si c'était le cas, tu ne pourrais pas récupérer coté serveur les valeurs dans le tableau GET ;)
Bon voilà, finalement, dans mon projet, j'ai juste remplacé les fonctions ajax de prototype par les fonctions ajax équivalentes de jquery. Je n'ai rien changé à mon organisation que je vous présente ci-dessous dès fois qu'elle puisse servir à quelqu'un.
Voici mon côté client :
Code:
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 var jq = jQuery.noConflict();//Ben oui j'utilise prototype function Ajax_Ap_RaffraichirFormulaire() { //Traitement ... var donneesEnJSON = stringify(monObjet); jq.ajax( { url: 'requetes/requetes.php', type: "GET", dataType: "json", data: { idParam: 1, donneesRequete: donneesEnJSON }, success: AjaxJQ_Rep_RaffraichirFormulaire } ); //Traitement ... } function AjaxJQ_Rep_RaffraichirFormulaire(data) {//data est donc un objet javascript //Traitement ... }
Et voici mon côté serveur :
Code:
1
2
3
4
5
6
7
8
9 //Récupération des données client. $DonneesRequete = json_decode ($_GET["donneesRequete"]); //Puis réalisation de mon traitement bla bla bla ... //Enfin formulation de la réponse serveur. $json = json_encode($monObjetRetour); echo $json;
Merci à tous ! ;)
Bonjour à tous, je remonte ce topic plutôt que d'en créer un autre pour éviter de disperser les informations.
J'essaie tant bien que mal de faire passer un objet Json avec Jquery vers mon serveur php.
J'ai donc dans mon fichier javascript :
Code:
1
2
3
4
5
6
7 $.getJSON("http://url/test.php", // le fichier qui recevra la requête {"lapin":{"tomate":"farcie","chocolat":"chaud"},"couleur":"bleu"}, function(data){ alert(data.message1); }
Et quand je tente de lire les données sur le serveur voilà ce qui se passe :
bleu est bien renvoyé dans ce cas, tout va bienCode:
1
2 $chaine=$_GET['couleur']; $reponse['message1'] = $chaine;
mais
null est renvoyé au lieu de farcie.Code:
1
2 $chaine=json_decode($_GET['lapin']); $reponse['message1'] = $chaine->tomate;
Pourtant, si je ne passe plus par javascript, en ecrivant directement la chaine sur le fichier php
la j'ai bien "farcie" qui s'affiche.Code:
1
2
3 $chaine='{"lapin":{"tomate":"farcie","chocolat":"chaud"},"couleur":"bleu"}'; $toto=json_decode($chaine); echo $toto->lapin->tomate;
Je suis donc un peu perdu, si quelqu'un pouvait m'aider, merci !