ASP.NET的OnClientClick与OnClick事件

OnClientClick是客户端事件方法.通常采用JavaScript来进行处理.也就是直接在IE端运行.一点击就运行.javascript

OnClick事件是服务器端事件处理方法,在服务器端,也就是IIS中运行.点击按钮后,执行postback,再运行.java

若是一个按钮上咱们同时有客户端的OnClientClick方法又有OnClick事件处理方法,如何才能按照正常的逻辑运行呢?c#

OnClientClick中咱们经常使用来作一些客户端的检测.固然放在服务器也能够作一样的检测,但这样作的代价是与服务器进行交互,消耗资源。服务器

例:函数

test()为一javascript函数.post

<script type="text/javascript">
        function test() {
            var value = document.getElementById("<%=t1.ClientID%>").value;
            if (value == "") {
                alert("不能为空值");
                return false;
            }
        }
    </script>

t1为一文本框,判断输入内容是否为空
spa

<asp:TextBox ID="t1" runat="server"></asp:TextBox>
 <asp:Button ID="Button1" runat="server" Text="提交"  OnClientClick="return test()" onclick="Button1_Click"  />

须要注意的是当咱们当击这个按钮时,自动先执行的客户端,再执行服务器端的.若是客户端返回的是false,那么服务器端对应的方法永远不会执行.这样就达到检测,只有经过才去执行服务器端的方法.code

也就是说若是咱们上面写成:orm

<asp:Button ID="Button1" runat="server" Text="提交"  OnClientClick="test();return false" onclick="Button1_Click"  />

那么无论test()执行的结果如何.服务器端对应的Button1_Click方法都永远不会执行.由于return false使得始终使客户端返回falseserver

若是咱们写成:

<asp:Button ID="Button1" runat="server" Text="提交"  OnClientClick="test()" onclick="Button1_Click"  />

那么Button1_Click都有会发生.一样也就达不到效果.也就是说你没有经过检测也去执行服务器的方法了.

还能够经过Button1.Attributes.Add("onclick", "test()");的方法来触发客户端事件

相关文章
相关标签/搜索