以下のように、phpファイルにajaxリクエストを送信しています。
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);
}
})
}
これは、submit時に関数を呼び出して送信されます。
<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>
問題は、php変数のユーザーIDがajaxでcheck_code.phpページに送られないことです。
これは、サーバーサイドのページに複数の値を渡す正しい方法ですか?useridを渡さなくても、コードを渡すだけで問題なく動作します。
ありがとうございました。)
ここでは、POST
データのフォーマットについて説明します。
key1=value1&key2=value2&key3=value3
あなたの場合(セパレーターとしての&
に注意)。
'code=' + code + '&userid=' + userid
しかし、データをオブジェクトとして指定した場合は、jQueryがそれを行ってくれます。
data: { code: code, userid: userid }