0

我对使用这个脚本以及它实际上是如何工作的感到有点困惑?

这是我的脚本:

 <script type="text/javascript">
        $(document).ready(function () {
            $('#<%=TextBox1.ClientID%>').change(function () {
                $('#various3').attr('href', $(this).val());
            });


                $("#<%=Button1.ClientID%>").click(function (event) {
                    setTimeout(showStickySuccessToast, 1000);
                    function showStickySuccessToast() {
                        $().toastmessage('showToast', {
                            text: 'Finished taking Screenshot!',
                            sticky: false,
                            position: 'middle-center',
                            type: 'success',
                            closeText: '',
                            close: function () {

                            }
                        });
                    }

                })                
        });
      </script>

这是我的按钮:

<a id="various3" href="#"><asp:Button ID="Button1" runat="server" 
    Text="Button" OnClientClick="Button1_Click"/></a>

这是我的 button1_Click 事件代码:

Protected Sub Button1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button1.Click
    Dim NewTh As New Threading.Thread(AddressOf DoIT)
    NewTh.SetApartmentState(Threading.ApartmentState.STA)
    NewTh.Start()
    ImgPreview.ImageUrl = "~/uploads/Sample.jpg"
End Sub

现在,如果我单击按钮,它应该打开 iframe 并显示我能够执行的消息。现在的问题是如何同时调用代码隐藏中的 button1_Click 事件。我已经使用了如下所示OnClickOnClientClick事件,但它不起作用,我没有收到任何错误。

4

2 回答 2

1

看起来你已经把事情倒退了:

<asp:Button ID="Button1" runat="server" OnClick="Button1_Click" />

上面的示例假定这Button1_Click是代码隐藏的单击事件处理程序。由于您在 jQuery 中分配客户端单击事件,因此您根本不需要使用OnClientClick

编辑

我会检查以确保验证不会干扰点击。您可以通过CausesValidation="false"在 Button 上进行设置来测试它。

于 2011-11-22T15:33:04.240 回答
1

Onclick= 引发回发,执行服务器事件处理程序。

OnClientClick= 引发客户端点击事件,您可以调用 javascript 函数,但不能直接处理 asp 事件,尽管在调用 javascript 函数后会发生回发。

于 2011-11-22T15:28:33.780 回答