Estoy enviando una petición ajax a un archivo php como se muestra aquí:
function checkDB(code, userid)
{
$.ajax({
type: "POST",
url: "<?php bloginfo('template_url'); ?>/profile/check_code.php",
data: 'code='+code+'userid='+userid,
datatype: "html",
success: function(result){
if(result == 0)
{
$('#success').html( code + ' has been redeemed!');
// alert('success');//testing purposes
}
else if(result == 2)
{
$('#err').html( code + ' already exists and has already been redeemed....');
//alert('fail');//testing purposes
}else if(result == 1){
$('#err').html( code + ' redeem code doesnt exist');
}
alert(result);
}
})
}
Esto se envía llamando a la función en submit, así:
<form method="post" class="sc_ajaxxx" id="sc_add_voucherx" name="sc_ajax"
onsubmit="checkDB(document.sc_ajax.sc_voucher_code.value, <?php echo $user_id ?>); return false;">
</form>
El problema es que la variable php de identificación del usuario no se envía a la página check_code.php por ajax.
¿Es esta la forma correcta de pasar varios valores a una página del lado del servidor? Sin pasar el userid, funciona bien sólo pasando el código.
Gracias chicos :)
Así es como deben formatearse los datos POST
:
key1=value1&key2=value2&key3=value3
En su caso (observe el &
como separador):
'code=' + code + '&userid=' + userid
Pero jQuery lo hace por ti si especificas tus datos como un objeto:
data: { code: code, userid: userid }