作家
登录

Textbox控件注册回车事件及触发按钮提交事件具体实现

作者: 来源:www.28hudong.com 2013-03-30 00:09:27 阅读 我要评论

引子: 在ASP.Net页面中textbox的index为1(或n),其后的提交按钮index为2(n+1),光标在textbox中,回车后自动焦点移动到后面的button上,会触发button的点击事件。 但在Lyncplus客户端中访问Web页面时遇到了TextBox控件回车自动完成按钮的提交事件失效的情况(应该是自动切换焦点)。 由于并且该服务端TextBox控件没有提供OnKeyPress或OnKeyDown等事件,也无法针对回车事件写后台代码来调用Button按钮的点击事件。 于是上网查找相关的介绍,最终解决了以下两个问题: (一)、实现在TextBox控件回车事件中 执行JS代码,来控制页面元素的值。 (二)、实现在TextBox控件回车事件中 调用服务端控件的点击事件,来执行服务端C#代码,实现相关的功能。 具体实现如下: 一、注册和触发服务端TextBox控件回车事件 1.PageLoad事件代码: 复制代码 代码如下: protected void Page_Load(object sender, EventArgs e) { MessageTxt.Attributes.Add("onkeypress", "EnterTextBox()"); MessageTxt.Attributes.Add("onkeydown", "EnterTextBox()"); } 2.javascript代码: 复制代码 代码如下: <script language="javascript"> function EnterTextBox() { if (event.keyCode == 13 && document.all["MessageTxt"].value != "") //按下了回车,并且文本框里有值 { $("#<%=hidKeywords.ClientID%>").val($("#<%=MessageTxt.ClientID%>").val().replace(/[^u0000-u00FF]/g, function ($0) { return escape($0).replace(/(%u)(w{4})/gi, "&#x$2;") })); } } </script> 二、TextBox控件回车事件中调用服务端Button控件点击事件 1.PageLoad事件代码: 同上。 复制代码 代码如下: protected void Page_Load(object sender, EventArgs e) { MessageTxt.Attributes.Add("onkeypress", "EnterTextBox()"); MessageTxt.Attributes.Add("onkeydown", "EnterTextBox()"); } 2.javascript代码: 注意使用原始的dom对象获取按钮,使用Jquery获取不到。 复制代码 代码如下: <script language="javascript"> function EnterTextBox() { var button = document.getElementById('<%=btnSearch.ClientID%>');//获取服务端控件对应的页面对象 if (event.keyCode == 13) //按下了回车 {   button.click(); event.returnValue = false; } } </script>

  推荐阅读

  jQuery 淡入淡出 png图在ie8下有黑色边框的解决方法

往带有png图的类里加红色字的部分 复制代码 代码如下:background-image:url(******.png)!important;background-image:url(../images/space.gif);/*space.gif 是一个透明的图片文件*/filter:progid:DXImageTransfor>>>详细阅读


本文标题:Textbox控件注册回车事件及触发按钮提交事件具体实现

地址:http://www.17bianji.com/kaifa2/JS/22300.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)