我正在使用 jQuery 的 AJAX 和 Codeigniter PHP 框架制作一个注册表单,但是 codeigniter 并不重要,如果你看到奇怪echo form_open();
或其他奇怪的东西,别担心,它们都是 codeigniter。
好的,这是我的代码问题。我在下面使用 jquery 尝试了简单的帖子(在 php 代码中,其他所有内容都被省略了,并添加了一个简单的 echo 'hello, world!'; 函数,它可以工作/给我一个 hello,world!):
$.post( 'ajax_signup_username' ,function(result){
$(span_error).html(result);
} );
但是当我在其中传递一个帖子数据时,它不起作用(不输出任何结果,请注意我正在使用下面编写的完整 PHP 代码):
$.post( 'ajax_signup_username', {php_username_error:username_value} ,function(result){
$(span_error).html(result);
} );
我试过搜索 SO,但提供的解决方案并没有解决这个问题。知道有什么问题吗?
以下是完整代码:
以下是html代码:
<body>
<?php $attr = array( 'onsubmit' => 'return final_val()' ); echo form_open('formValidation/signUp',$attr); ?>
<p>Username: <input type="text" onBlur="username_val()" value="<?php echo set_value('username')?>" name="username" maxlength="50" /><span name="username_error"><?php echo form_error('username'); ?></p></span>
<p>Email: <input type="text" onBlur="email_val()" value="<?php echo set_value('email')?>" name="email" maxlength="50" /><span name="email_error"><?php echo form_error('email'); ?></p></span>
<p>Password: <input type="password" onBlur="pass_val()" value="<?php echo set_value('pass')?>" name="pass" maxlength="50" autocomplete="off"/><span name="pass_error"><?php echo form_error('pass'); ?></p></span>
<p>Password Confirm: <input type="password" onBlur="pass_val()" value="<?php echo set_value('passconf')?>" name="passconf" maxlength="50" autocomplete="off" /><span name="passconf_error"><?php echo form_error('passconf'); ?></p></span>
<p><input type="submit" value="SIGN UP!" name="signup"/></p>
</form>
</body>
以下是php代码:
function ajax_signup_username(){
$username = $_POST['php_username_error'];
$uniqueUn = $this->db->prepare("SELECT * FROM iowfiwefwmember WHERE username=:username");
$uniqueUn->bindParam(':username', $username);
$uniqueUn->execute();
$count1 = $uniqueUn->fetch();
if( $count1 == FALSE ){
echo 'USERNAME AVAILABLE!';
}else{
echo 'USERNAME IS ALREADY USED!';
}
}
以下是javascript代码:
function username_val(){
$.ajaxSetup({ cache : false });
username_value = $("input[name='username']").val();
span_error = "span[name='username_error']";
//$(span_error).load('ajax_signup_username', {php_username_error:username_value}); <-- also doesn't work [ $.ajaxSetup() is set to POST ]
$.post( 'ajax_signup_username', {php_username_error:username_value} ,function(result){
$(span_error).html(result);
} );
}