繁体   English   中英

Ajax事件只工作一次

[英]Ajax event only working once

当我输入错误的细节并运行它。 它弹出错误消息,但如果我然后输入正确的详细信息,然后单击再次运行它。 登录按钮变为“正在连接...”,但它没有其他任何事情发生

$(document).ready(function() {

    var width = ( $(".main").width() - 5);
    if (width < 300) {
        $(".logo-img").css({"width":width});
    };

    $("#error").hide();

    $(function() {
        $('#login').on('click', function(e){
            e.preventDefault();

            var token = $('#token').val();
            var username = $('#username').val();
            var password = $('#password').val();
            var remember = $('#remember:checked').val();

            $.ajax({
                url: 'core/functions/ajaxLogin.php',
                method: 'POST',
                data: { 'username' : username,
                        'password' : password, 
                        'remember' : remember, 
                        'token' : token },
                dataType: 'html',
                cache: false,
                beforeSend: function() { $('#login').val('Connecting...') },
                success: function( data ) {
                    if (data == 'success') {
                        setTimeout( "window.location.href='backorderbook';", 500 );
                    } else if( data == 'userorpass' ) {
                        $('#error').fadeIn();
                        $('#error_message')
                           .html('username or password were entered incorrectly');
                        $('#error').delay(3500).fadeOut();
                        $('#login').val('Sign In');
                    };
                }
            });
        });
    });
});

工作一次的原因。

当你的ajax被解雇时,首先要做的是显示连接..然后当你得到响应时,你的声明说的是data

if data == success //redirects

elseif data == userpass //show you have invalid username/password and clear html

那么如果您的数据不是成功/用户通过怎么办?

它只会运行你的ajax beforeSend()而不会删除你运行一次的连接。

我建议你的数据应该是一个对象并检查它上面的消息是否有错误,简而言之就是你的后端只有jquery显示该消息

加载登录页面并使用Ajax发送时会生成令牌。 但我的PHP令牌系统不喜欢反复发送相同的令牌并阻止请求。

用Fiddler运行你的函数..和/或将错误参数添加到你的ajax ...赔率是你的网络请求不成功。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM