0

我有一个登录页面,当有人尝试登录时,它会向服务器发送一个 ajax 请求。ajax 会转到服务器,因为他们登录了我已经能够确认。但问题是我的 jQuery 似乎没有收到 JSON。

我的控制器中的功能是:

public function login(){
    $this->load->model('users_model');
    if((!!$this->input->post('email')) || (!!$this->input->post('password'))){
        $ret = $this->users_model->login($this->input->post('email'), $this->input->post('password'));
        echo json_encode(array('status' => "OK", 'msg' => 'Logged in!')); //also tried return
    }else{
        echo json_encode(array('status' => 'FAIL', "msg" => 'Invalid Email or Pass'));
    }
}

AJAX 函数是:

<script type="text/javascript">
    $(document).ready(function() {
        $("#login").ajaxForm(function(json) {
            alert(json);
        if(json.status == true) {
                alert(json.msg);
            //window.location = '<?php echo base_url(); ?>';
            } else {
                alert("Problem");
                $(".error_msg").html(json.msg);
            };
        });
    });
</script>

如果我提醒 json 变量,它是空白的,如果我做 json.msg 它说未定义。那么......我必须做些什么才能得到这个回调,一个json对象或任何类型的对象?请解释一下,以便我理解问题,而不仅仅是如何解决它。非常感谢!

编辑:这也是表格:

<span class="error_msg"></span></br>

<form id="login" action="<?php echo base_url(); ?>users/login" method="POST" enctype="multipart/form-data">
    Email: <input name="email" type="text"/></br>
    Password: <input type="password" name="password"></br>
    <input type="submit"/>
</form>
4

1 回答 1

1

啊,我想我明白了。

这是你使用的插件吗?http://www.malsup.com/jquery/form/#api

在这种情况下,使用ajaxSubmit,而不是ajaxForm

其他在线示例执行以下操作:

$(document).ready(function() {
    $('#login').submit(function() {
    $("#login").ajaxSubmit({
        success: function(json) {
            alert(json);
            if(json.status == true) {
                alert(json.msg);
                //window.location = '<?php echo base_url(); ?>';
            } else {
                alert("Problem");
                $(".error_msg").html(json.msg);
            }
        }
    });
    return false;
    });
});
于 2013-03-27T03:18:11.703 回答