如何实现服务器断控件事件在客户端运行 我的意思是,例如有一个服务器断控件Textbox,输入年龄之后需要马上判断该框中输入的是否为一个整数(客户端运行,弹出提示对话框),我之所以不采用验证控件的原因在于页面上需要填写的内容很多,而页面又要非常的紧凑,采用验证之后错误信息会占去比较大的幅面。请高手指点。 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 function check(e){ var k = window.event.keyCode; if (k < 48 || k > 57){ alert("你输入的不是数字!") window.event.keyCode = 0 ;}} xmlhttp: script callbackhttp://www.codeproject.com/aspnet/ScriptCallbackFramework.asp?print=true 验证控件可以设置成不在页面上显示,而是集中到一个SUM里显示,还可以用对话框来显示的呀。 private void button4_Click(object sender, System.EventArgs e) { //using System.Text.RegularExpressions; string str="23sd呜SDF呜95列gfwef随地56国GE嘎4"; MatchCollection ms=Regex.Matches(str,"[\u4e00-\u9fa5]"); string sss=null; for(int i=0;i<ms.Count;i++) { sss+=ms[i].Value; } MessageBox.Show(sss); if (Regex.IsMatch(str,"[0-9]"))//数字 MessageBox.Show("字符串中包含有数字"); if (Regex.IsMatch(str,"[a-z]"))//小写字母 MessageBox.Show("字符串中包含有小写字母"); if (Regex.IsMatch(str,"[A-Z]"))//大写字母 MessageBox.Show("字符串中包含有小写字母"); if (Regex.IsMatch(str,"[a-zA-Z]"))//所有字母 MessageBox.Show("字符串中包含有字母"); if (Regex.IsMatch(str,"[\u4e00-\u9fa5]"))//汉字 MessageBox.Show("字符串中包含有汉字"); } Asp.net 中在客户端触发服务端事件分为两种情况: 一. WebControls中的Button 和HtmlControls中的Type为submit的HtmlInputButton 这两种按钮最终到客户端的表现形式为: <input name="Submit1" id="Submit1" type="submit" value=”Submit”>,这是Form表单的提交按钮,点击以后会作为参数发送到服务端,参数是这样的: 控件的name属性=控件的value值,对应上面的例子就是:Submit1= Submit。 服务端会根据接收到的控件的name属性的这个key来得知是这个按钮被点击了,从而在服务端触发这个按钮的点击事件。 二. HtmlControls 中的 Type为button的HtmlInputButton 和其它所有的控件事件,比如LinkButton点击,TextBox的Change事件等等: 这些事件在客户端产生后会经过一个统一的机制发送到服务端。 1. 首先asp.net页框架会使用两个Hidden域来存放表示是哪个控件触发的事件,以及事件的参数: <!—表示触发事件的控件,一般是这个控件的name --> <input type="hidden" name="__EVENTTARGET" value="" /> <!—表示触发事件的参数,一般是当某个控件有两个以上的事件时,用来区别是哪个事件 --> <input type="hidden" name="__EVENTARGUMENT" value="" /> 2. 服务端会生成一个jscript的方法来处理所有这些事件的发送,这段代码是: <script language="javascript"> <!-- function __doPostBack(eventTarget, eventArgument) { var theform = document.WebForm2; theform.__EVENTTARGET.value = eventTarget; theform.__EVENTARGUMENT.value = eventArgument; theform.submit(); } // --> </script> 3. 每个会引发服务端事件的控件都会在响应的客户端事件中调用上面的代码: 比如,HtmlControls 中的 Type为button的HtmlInputButton的点击事件 <!—客户端的点击事件调用__doPostBack,eventTarget 参数为'Button2',表示是name为'Button2'控件触发的事件,eventArgument 为空,表示这个Type为button的HtmlInputButton只有一个客户端触发的服务端事件--> <input language="javascript" onclick="__doPostBack('Button2','')" name="Button2" id="Button2" type="button" value="Button" /> 又比如,TextBox控件的Change事件 <!—客户端的onchange事件调用__doPostBack,eventTarget 参数为'TextBox1',表示是name为'TextBox1'控件触发的事件,而TextBox控件只有一个客户端触发的服务端事件TextChanged,故服务器就会去触发这个TextBox的TextChanged事件-> <input name="TextBox1" type="text" id="TextBox1" onchange="__doPostBack('TextBox1','')" language="javascript" /> 4. 客户端触发事件后调用__doPostBack方法,将表示触发的控件源的eventTarget 和事件参数eventArgument分别付给两个隐藏域__EVENTTARGET和__EVENTARGUMENT,然后提交Form,在服务端根据__EVENTTARGET和__EVENTARGUMENT来判断是哪个控件的什么事件触发了。 _____________采用验证控件的原因在于页面上需要填写的内容很多,而页面又要非常的紧凑,采用验证之后错误信息会占去比较大的幅面。_____________你可以使用弹出错误对话框啊RequiredFieldValidator的Display="None"再在页面加上<table border="0" align="center" width="610"> <tr valign="top"> <td align="middle"><asp:ValidationSummary id="Errors" runat="server" ShowMessageBox="True" HeaderText="你的输入有以下错误:" ShowSummary="false"></asp:ValidationSummary> </td> </tr> </table>这段代码是不会在页面占用空间的退一步,你用JS验证function IsDigit(cCheck) { return (('0'<=cCheck) && (cCheck<='9'));//0~~~~~~9 }function VerifyUser(){ tempuser=document.form.user.value; for (nIndex=0; nIndex<tempuser.length; nIndex++) { cCheck =tempuser.charAt(nIndex); if (!(IsDigit(cCheck))) { alert("号码只能是数字!"); document.SearchUser.user.focus(); return false; } }} 更正一下function VerifyUser(){ tempuser=document.from1.textbox1.value; for (nIndex=0; nIndex<tempuser.length; nIndex++) { cCheck =tempuser.charAt(nIndex); if (!(IsDigit(cCheck))) { alert("号码只能是数字!"); document.from1.textbox1.focus(); return false; } }} 在客户端验证的话用Javascript比较方便 高分求购物车实现思路??? 网站发布中,非托管DllImport的Dll应该放在何处? 在aspx中能否获取到当页TextBox的值 这2天都在纠结的一个需求 XML读取问题 ImageButton在FireFox下无效~~~~? 由连接词判断数据库 关于ie7和火狐的2个问题 hyperlink棘手问题 这代码怎么提高性能 static string [] fileds={};该如何初始化 让他可以接受可变的字符串 递归问题
{
var k = window.event.keyCode;
if (k < 48 || k > 57){
alert("你输入的不是数字!")
window.event.keyCode = 0 ;}
}
{
//using System.Text.RegularExpressions;
string str="23sd呜SDF呜95列gfwef随地56国GE嘎4";
MatchCollection ms=Regex.Matches(str,"[\u4e00-\u9fa5]");
string sss=null;
for(int i=0;i<ms.Count;i++)
{
sss+=ms[i].Value;
}
MessageBox.Show(sss); if (Regex.IsMatch(str,"[0-9]"))//数字
MessageBox.Show("字符串中包含有数字");
if (Regex.IsMatch(str,"[a-z]"))//小写字母
MessageBox.Show("字符串中包含有小写字母");
if (Regex.IsMatch(str,"[A-Z]"))//大写字母
MessageBox.Show("字符串中包含有小写字母");
if (Regex.IsMatch(str,"[a-zA-Z]"))//所有字母
MessageBox.Show("字符串中包含有字母");
if (Regex.IsMatch(str,"[\u4e00-\u9fa5]"))//汉字
MessageBox.Show("字符串中包含有汉字");
}
一. WebControls中的Button 和HtmlControls中的Type为submit的HtmlInputButton 这两种按钮最终到客户端的表现形式为: <input name="Submit1" id="Submit1" type="submit" value=”Submit”>,这是Form表单的提交按钮,点击以后会作为参数发送到服务端,参数是这样的: 控件的name属性=控件的value值,对应上面的例子就是:Submit1= Submit。 服务端会根据接收到的控件的name属性的这个key来得知是这个按钮被点击了,从而在服务端触发这个按钮的点击事件。 二. HtmlControls 中的 Type为button的HtmlInputButton 和其它所有的控件事件,比如LinkButton点击,TextBox的Change事件等等: 这些事件在客户端产生后会经过一个统一的机制发送到服务端。 1. 首先asp.net页框架会使用两个Hidden域来存放表示是哪个控件触发的事件,以及事件的参数: <!—表示触发事件的控件,一般是这个控件的name --> <input type="hidden" name="__EVENTTARGET" value="" /> <!—表示触发事件的参数,一般是当某个控件有两个以上的事件时,用来区别是哪个事件 --> <input type="hidden" name="__EVENTARGUMENT" value="" /> 2. 服务端会生成一个jscript的方法来处理所有这些事件的发送,这段代码是: <script language="javascript"> <!-- function __doPostBack(eventTarget, eventArgument) { var theform = document.WebForm2; theform.__EVENTTARGET.value = eventTarget; theform.__EVENTARGUMENT.value = eventArgument; theform.submit(); } // --> </script> 3. 每个会引发服务端事件的控件都会在响应的客户端事件中调用上面的代码: 比如,HtmlControls 中的 Type为button的HtmlInputButton的点击事件 <!—客户端的点击事件调用__doPostBack,eventTarget 参数为'Button2',表示是name为'Button2'控件触发的事件,eventArgument 为空,表示这个Type为button的HtmlInputButton只有一个客户端触发的服务端事件--> <input language="javascript" onclick="__doPostBack('Button2','')" name="Button2" id="Button2" type="button" value="Button" /> 又比如,TextBox控件的Change事件 <!—客户端的onchange事件调用__doPostBack,eventTarget 参数为'TextBox1',表示是name为'TextBox1'控件触发的事件,而TextBox控件只有一个客户端触发的服务端事件TextChanged,故服务器就会去触发这个TextBox的TextChanged事件-> <input name="TextBox1" type="text" id="TextBox1" onchange="__doPostBack('TextBox1','')" language="javascript" /> 4. 客户端触发事件后调用__doPostBack方法,将表示触发的控件源的eventTarget 和事件参数eventArgument分别付给两个隐藏域__EVENTTARGET和__EVENTARGUMENT,然后提交Form,在服务端根据__EVENTTARGET和__EVENTARGUMENT来判断是哪个控件的什么事件触发了。
采用验证控件的原因在于页面上需要填写的内容很多,而页面又要非常的紧凑,采用验证之后错误信息会占去比较大的幅面。
_____________
你可以使用弹出错误对话框啊RequiredFieldValidator的Display="None"
再在页面加上
<table border="0" align="center" width="610">
<tr valign="top">
<td align="middle"><asp:ValidationSummary id="Errors" runat="server" ShowMessageBox="True" HeaderText="你的输入有以下错误:" ShowSummary="false"></asp:ValidationSummary>
</td>
</tr>
</table>
这段代码是不会在页面占用空间的退一步,你用JS验证
function IsDigit(cCheck)
{
return (('0'<=cCheck) && (cCheck<='9'));//0~~~~~~9
}
function VerifyUser()
{
tempuser=document.form.user.value;
for (nIndex=0; nIndex<tempuser.length; nIndex++)
{
cCheck =tempuser.charAt(nIndex);
if (!(IsDigit(cCheck)))
{
alert("号码只能是数字!");
document.SearchUser.user.focus();
return false;
}
}
}
function VerifyUser()
{
tempuser=document.from1.textbox1.value;
for (nIndex=0; nIndex<tempuser.length; nIndex++)
{
cCheck =tempuser.charAt(nIndex);
if (!(IsDigit(cCheck)))
{
alert("号码只能是数字!");
document.from1.textbox1.focus();
return false;
}
}
}