ASP.NET的OnClientClick与OnClick事件
2024-08-21 12:51:59
OnClientClick是客户端事件方法.一般采用JavaScript来进行处理.也就是直接在IE端运行.一点击就运行.
OnClick事件是服务器端事件处理方法,在服务器端,也就是IIS中运行.点击按钮后,执行postback,再运行.
如果一个按钮上我们同时有客户端的OnClientClick方法又有OnClick事件处理方法,如何才能按照正常的逻辑运行呢?
OnClientClick中我们常用来做一些客户端的检测.当然放在服务器也可以做同样的检测,但这样做的代价是与服务器进行交互,消耗资源。
例:
test()为一javascript函数.
<script type="text/javascript">
function test() {
var value = document.getElementById("<%=t1.ClientID%>").value;
if (value == "") {
alert("不能为空值");
return false;
}
}
</script>
t1为一文本框,判断输入内容是否为空
<asp:TextBox ID="t1" runat="server"></asp:TextBox>
<asp:Button ID="Button1" runat="server" Text="提交" OnClientClick="return test()" onclick="Button1_Click" />
需要注意的是当我们当击这个按钮时,自动先执行的客户端,再执行服务器端的.如果客户端返回的是false,那么服务器端对应的方法永远不会执行.这样就达到检测,只有通过才去执行服务器端的方法.
也就是说如果我们上面写成:
<asp:Button ID="Button1" runat="server" Text="提交" OnClientClick="test();return false" onclick="Button1_Click" />
那么不管test()执行的结果如何.服务器端对应的Button1_Click方法都永远不会执行.因为return false使得始终使客户端返回false
如果我们写成:
<asp:Button ID="Button1" runat="server" Text="提交" OnClientClick="test()" onclick="Button1_Click" />
那么Button1_Click都有会发生.同样也就达不到效果.也就是说你没有通过检测也去执行服务器的方法了.
我们还可以通过Button1.Attributes.Add("onclick", "test()");的方法来触发客户端事件
转自 http://blog.163.com/huang_qy/blog/static/615601452012101535413943/
最新文章
- bs4_3select()
- thinkphp的各种内部函数 D()、F()、S()、C()、L()、A()、I()
- MR并行算法编程过程中遇到问题的思考
- jQuery live与bind的区别
- Webform和MVC,为什么MVC更好一些?
- 再探LIS
- Qt信号槽机制的实现(面试的感悟,猜测每一个类保存的一个信号和槽的二维表,实际使用函数指针 元对象 还有类型安全的检查设定等等)
- 从零开始学C++之对象的使用(二):四种对象生存期和作用域、static 用法总结
- k-近邻算法实例
- Python自动化测试、性能测试成长路线图
- Java之增强的for 循环
- 性能测试工具Locust的使用
- String 和 StringBuilder
- jenkins运行脚本生成HTML报告时遇到的问题
- Centos6下关于系统用户密码规则-运维笔记
- Eclipse_设置_01_自动提示
- Spark Streaming之五:Window窗体相关操作
- MVC实现加载更多
- Android Studio中实现AIDL
- SpringBoot自动化配置的注解开关原理