0

我正在尝试使用 asp.net 和 jQuery mobile 做一个登录页面。

当用户点击登录按钮时,我先在 c# 中进行一些处理,然后调用 JavaScript。

问题是当我点击登录按钮时,页面似乎在执行 JavaScript 之前重新加载,我不希望这样。

这是我的代码:

<asp:Button name="login" ID="btnLogin" runat="server" Text="Login" OnClick="btnLogin_Click" />

C#:

protected void btnLogin_Click(object sender, EventArgs e)
{
    if (String.Format("{0}", Request.Form["username"]) != "" && String.Format("{0}", Request.Form["password"]) != "")
    {

        ClientScript.RegisterStartupScript(GetType(), "key", "login();", true);

    }
    else
    {
        //todo
    }

}

JS/jQuery:

<script type="text/javascript">
    function login() {
        jQuery(function () {
            jQuery.ajax({
                beforeSend: function () {
                    $.mobile.loading('show', {
                        text: 'Processing...',
                        textVisible: true,
                        theme: 'a'
                    });
                }, 
                type: "GET",
                url: "Handler.ashx",
                data: "method=validate",
                success: function (data) {

                    $.mobile.loading('hide');
                    //$.mobile.changePage("HomePage.aspx", { transition: "fade" });

                }
            });
        });
    };
</script>

任何想法?

谢谢!

编辑:我仍然需要服务器端代码来处理 C# 中的密码加密

4

2 回答 2

1

The OnClick event is a server-side event. That is why it is posting back. You want to use the OnClientClick event. This is for client-side code to run before the OnClick event is invoked.

That said, what server-side code do you need to run before calling the javascript? What exactly are you trying to do?

Please explain the process flow in more detail.

于 2012-10-11T22:28:21.037 回答
0

这将允许您在客户端处理单击事件。evt.preventDefault将确保该按钮不会回发到服务器。

$('#btnLogin').click(function(evt) {

    if(!myCondition) {
        evt.preventDefault();
    }
    else{
    }
});
于 2012-10-11T22:30:46.883 回答