教程集 www.jiaochengji.com
教程集 >  脚本编程  >  Asp.net  >  正文 asp.net Textbox控件注册回车事件与触发按钮提交事件的实现方法

asp.net Textbox控件注册回车事件与触发按钮提交事件的实现方法

发布时间:2015-12-31   编辑:jiaochengji.com
以下代码解决了二个问题:(一)、实现在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">
/**
  回车事件
 by http://www.jbxue.com
*/
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>

附:
asp.net中textbox的index为1(或n),其后的提交按钮index为2(n+1),光标在textbox中,回车后自动焦点移动到后面的button上,会触发button的点击事件。
但在Lyncplus客户端中访问Web页面时,TextBox控件回车自动完成按钮的提交事件失效。由于该服务端TextBox控件没有提供OnKeyPress或OnKeyDown等事件,也无法针对回车事件写后台代码来调用Button按钮的点击事件。

所以从网上找了些资料,实现了上面的两个代码,供大家学习参考。

您可能感兴趣的文章:
asp.net Textbox控件注册回车事件与触发按钮提交事件的实现方法
js回车提交表单的代码
Asp.Net事件模型总结
net入门教程:ASP.NET Button 控件
js触发onchange事件方法
JavaScript 提交表单的实例分享
js 回车提交表单二种方法
ASP.NET2.0泛型和匿名方法介绍
ASP.NET页面事件:顺序与回传方法详解
C#动态创建组件、属性及事件方法详解

关键词: textbox  回车事件  控件   
[关闭]
~ ~