簡體   English   中英

觸發click事件后觸發一個函數

[英]fire a function after triggering a click event

怎么解決這個問題:

function Navigation(sender) {
    var senderID = sender.id;


    var answer = confirm("do you want to save your current layout ?");
    if (answer) {
        $("#loadingImg").css("display", "block");
        $("#<%=Button1.ClientID %>").click();
         //the next line is never fired
         if (senderID == "AboutClick") { setTimeout('ShowLoadingMsg()', 3000); } 

    }    
 }
function ShowLoadingMsg() {
   window.location="About.aspx";
}

<a href="javascript:void(0)" id="AboutClick" class="menu" onclick="Navigation(this);" >Navigate Click</a>
<asp:Button ID="Button1" runat="server" OnClick="btnSaveState_Click" style="display:none;" />

//服務器端:

 protected void btnSaveState_Click(object sender, EventArgs e)
{

     SaveState();

}

主要的問題是這條線永遠不會被解雇我在這里做錯了什么

這里的問題是$("#<%=Button1.ClientID %>").click(); 導致整個頁面重新加載。 在此之后設置超時的腳本並不重要,因為無論如何頁面都會刷新。

您可以嘗試將Button1放在UpdatePanel中 ,或者只是以其他方式解決問題,例如在同一方法中保存狀態和重定向。

嘗試這個:

<a href="#" id="AboutClick" class="menu trigger">Navigate Click</a>​

-

$(function(){
    $(".trigger").click(function(){
        var answer = confirm("do you want to save your current layout ?");
        if (answer) {
            $("#loadingImg").show();
            if (this.id == "AboutClick") { setTimeout('ShowLoadingMsg()', 3000); }
            $("#<%=Button1.ClientID %>").click();
        }  
    })       
})

function ShowLoadingMsg() {
   window.location="About.aspx";
}

在這里演示!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM