Calling an ASP.NET EventHandler from JavaScript

10,425

You could write in

__doPostBack('<%=myButton.ClientID%>','OnClick');

or a bit better and less error prone use the ASP.Net ClientScriptManager

<%= Page.ClientScript.GetPostBackEventReference(myButton, String.Empty) %>; 

The second actually writes __doSubmit under the covers but you are getting the ASP.Net framework to do it for you. Also th efirst one will post back the page but the second triggers the correct server side events as well. It integrates a lot better into the ASP.Net architecture. Either would work though.

This recent SO question explains it all far better than I can (or rather did at the time)

Share:
10,425
Mono Developer
Author by

Mono Developer

Updated on June 04, 2022

Comments

  • Mono Developer
    Mono Developer almost 2 years

    I have a traditional ASP.NET Web Form. We used to have a button defined as follows:

    <asp:Button ID="myButton" Runat="server" OnClick="myButton_Click" />
    

    In the .aspx.cs page, I have the following:

    protected void myButton_Click(object sender, EventArgs e)
    {
      // Do Stuff
    }
    

    However, now someone has decided to use a fancy JavaScript framework. Essentially, I just have:

      <input type="button" id="myButton" onclick="someJSFunction()" />
      <script type="text/javascript">
        function someJSFunction() {
          // Need to execute "myButton_Click" here.
        }
      </script>
    

    How do I actually execute my original method on the server from here? I know this is a very bizarre question. I've simplified the code to try to and be a direct in communicating what I'm trying to accomplish. Can someone please tell me how to do this?

    Thank you so much!