0
$('#loginbtn').click(function() {
            var userName = document.getElementById('uid').value;
            var password = document.getElementById('pwd').value;

            $.ajax({
                type: "POST",
                url: "/LoginNew.aspx/Authenticate",
                data: "{ 'userName': '" + userName + "' ,'password': '" + password + "' }",
                async: false;
                contentType: "application/json; charset=utf-8",
                dataType: "json",
                success: a(),
                error: function(e) {
                    alert(e.valueOf());
                }
            });

         alert("test");
            function a() {
                window.location.href = "Login.aspx";
            }
        });

正如我已经接受了答案,它转到服务器端代码对用户进行身份验证并将控制权传递给“a”函数,但它不显示 login.aspx 页面......任何线索?

4

2 回答 2

3

它应该是

$('#loginbtn').click(function() {
    var userName = document.getElementById('uid').value;
    var password = document.getElementById('pwd').value;

    $.ajax({
        type : "POST",
        url : "/LoginNew.aspx/Authenticate",
        data : { 
            userName: userName ,
            password: password 
        },
        async : false, // not ; need to use ,
        contentType : "application/json; charset=utf-8",
        dataType : "json",
        success : a, // pass the callback reference, don't invoke it
        error : function(e) {
            alert(e.valueOf());
        }
    });

    alert("test");
    function a() {
        window.location.href = "Login.aspx";
    }
});
于 2013-08-06T13:40:47.193 回答
2

您生成的 JSON 无效。不要尝试手动生成 JSON,使用 JSON 库。

JSON.stringify({ userName: userName, password: password })

您正在调用 a()而不是分配a为成功处理程序。()如果要分配函数而不是其返回值,请删除。

于 2013-08-06T13:43:12.817 回答