Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Tratar objeto enviado por ajax

Estas en el tema de Tratar objeto enviado por ajax en el foro de PHP en Foros del Web. Wenas, No estoy seguro si el tema va en esta sección de PHP pero como mi duda principal esta del lado del servidor lo agrego ...
  #1 (permalink)  
Antiguo 25/09/2014, 21:39
Avatar de Maganius  
Fecha de Ingreso: septiembre-2010
Mensajes: 310
Antigüedad: 13 años, 6 meses
Puntos: 10
Tratar objeto enviado por ajax

Wenas,

No estoy seguro si el tema va en esta sección de PHP pero como mi duda principal esta del lado del servidor lo agrego aqui.

Estoy intentando enviar un objeto mediante ajax a un archivo PHP, el problema esta en que no se si estoy haciendo las cosas bien, les muestro un poco el código.

HTML
Código HTML:
Ver original
  1. <a href="#" class="send-estado-compra-web" data-rel="{estado:1,key:1985}">Aprobado</a>

Mi ídea era ir armando un objeto con los datos mediante data-rel para luego pasarlos por ajax a un archivo PHP.

JS
Código Javascript:
Ver original
  1. function sendPOST(a, b, t) {
  2.     var $data = JSON.stringify($(t).attr("data-rel"));
  3.  
  4.     $.ajax({
  5.         type: "POST",
  6.         url: a,
  7.         data: {datos:$data},
  8.         dataType: "json",
  9.         cache: !0,
  10.         success: function(a) {
  11.             b.html(a)
  12.         },
  13.         error: function(e) {
  14.             b.html('<h4 class="ajax-loading-error"><i class="fa fa-warning txt-color-orangeDark"></i> '+e.responseText+'</h4>')
  15.         },
  16.         async: !0
  17.     })
  18. }
a = url del PHP
b = contenido donde se va a cargar la respuesta del AJAX
t = paso el objeto del elemento cuando realizo el click = $(this);

PHP
Código PHP:
Ver original
  1. var_dump($_POST);
  2. $data = json_decode($_POST[0],true);
  3. echo $data;
  4.  
  5. El dump me muestra:  array(1) { ["datos"]=> string(21) ""{estado:1,key:1689}"" }
  6.  
  7. $data muestra = {estado:1,key:1689}

Los datos me los esta enviando como texto, pero yo los quiero enviar como un arreglo para luego poder acceder de la forma clasica: $data["estado"];

Al enviarlo como texto es imposible acceder como un arreglo.

De que forma puedo enviar mis datos para que del lado del servidor los trabaje como un arreglo?

O tal vez lo que intento no se pueda jaja.

Gracias!
  #2 (permalink)  
Antiguo 25/09/2014, 21:48
Avatar de Maganius  
Fecha de Ingreso: septiembre-2010
Mensajes: 310
Antigüedad: 13 años, 6 meses
Puntos: 10
Respuesta: Tratar objeto enviado por ajax

Despues de leer el topic me di cuenta que en realidad va en la sección javascript. Ya estoy dormido jaja que algun mod lo mueva.
  #3 (permalink)  
Antiguo 26/09/2014, 08:36
 
Fecha de Ingreso: septiembre-2012
Mensajes: 53
Antigüedad: 11 años, 7 meses
Puntos: 2
Respuesta: Tratar objeto enviado por ajax

Cuando tomas el atributo data-rell lo estas haciendo un string, y ya por si solo es un string lo que tienes que hacer es cambiar esto

Código Javascript:
Ver original
  1. var $data = JSON.stringify($(t).attr("data-rel"));

por esto

Código Javascript:
Ver original
  1. var $data = JSON.parse($(t).attr("data-rel"));

el JSON.parse() covierte el string que toma jquery del atributo data-rel y lo convierte en un onjeto Json.

Saludos!
  #4 (permalink)  
Antiguo 26/09/2014, 08:37
 
Fecha de Ingreso: septiembre-2012
Mensajes: 53
Antigüedad: 11 años, 7 meses
Puntos: 2
Respuesta: Tratar objeto enviado por ajax

el JSON.parse() convierte el string que toma jquery del atributo data-rel y lo convierte en un objeto Json.

con eso deberia de funcionar, Saludos!
  #5 (permalink)  
Antiguo 26/09/2014, 10:52
Avatar de Maganius  
Fecha de Ingreso: septiembre-2010
Mensajes: 310
Antigüedad: 13 años, 6 meses
Puntos: 10
Respuesta: Tratar objeto enviado por ajax

Muchas gracias gajosu, funciono perfectamente ahora puedo tratar el objecto adecuadamente.

Un dato por si alguien tiene la misma duda:

Cuando armen el objeto en el data-rel no utilizen comillas simples ' utilizen comillas dobles ya que las simples dan error.

Dejo el ejemplo funcionando.

Código HTML:
Ver original
  1. <li><a href="#" class="send-estado-compra-web" data-rel='{"estado":1,"key":1985}'>Aceptado</a></li>

Código Javascript:
Ver original
  1. function sendPOST(a, b, t) {
  2.     var $data = JSON.parse($(t).attr("data-rel"));
  3.    
  4.     $.ajax({
  5.         type: "POST",
  6.         url: a,
  7.     data: {datos:$data},
  8.     dataType: "json",
  9.         cache: !0,
  10.         success: function(a) {
  11.             b.html(a)
  12.         },
  13.         error: function(e) {
  14.             b.html('<h4 class="ajax-loading-error"><i class="fa fa-warning txt-color-orangeDark"></i> '+e.responseText+'</h4>')
  15.         },
  16.         async: !0
  17.     })
  18. }

Etiquetas: ajax, enviado, html, objeto
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 03:39.