校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > asp.net實現取消頁面表單內文本輸入框Enter響應的方法

asp.net實現取消頁面表單內文本輸入框Enter響應的方法

熱門標簽:濮陽外呼電銷系統怎么樣 天心智能電銷機器人 遂寧市地圖標注app 地圖標注的公司有哪些 代理接電話機器人如何取消 400電話辦理哪家性價比高 地圖定位圖標標注 塔城代理外呼系統 地圖標注專業團隊

本文實例講述了asp.net實現取消頁面表單內文本輸入框Enter響應的方法。分享給大家供大家參考,具體如下:

很早以前開發asp.net項目的時候遇到的:在一個服務器TextBox控件上按下 Enter鍵,頁面回發刷新一遍。后來google一下,發現這是asp.net2.0為表單處理專門設置的"Enter key"功能,關于asp.net ajax表單的enter key,你可以查看這一篇《ASP.NET基于Ajax的Enter鍵提交問題》。前面給出鏈接的兩篇都是叫我們怎么設置enter key默認觸發事件的?,F在有一個新需求是這樣的,錄入人員在錄入的時候按下enter鍵不提交表單(想想也是合理的,如果表單中錄入框較多,一不小心按下enter鍵頁面要回發多少次?),除非直接點擊服務器端提交按鈕。簡單地說,就是去掉表單元素的enter key功能。下面是我的實現:

一、初步分析和實現:

1、頁面繼承一個基類BasePage,基類繼承自Page類,在基類中注冊特定服務器控件的onkeydown腳本事件

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public class BasePage : System.Web.UI.Page
{
 public BasePage()
 {
 }
 protected override void OnInit(EventArgs e)
 {
  base.OnInit(e);
  CancelFormControlEnterKey(this.Page.Form.Controls);
 }
 /// summary>
 /// 在這里我們給Form中的服務器控件添加客戶端onkeydown腳步事件,防止服務器控件按下enter鍵直接回發
 /// /summary>
 /// param name="controls">/param>
 public static void CancelFormControlEnterKey(ControlCollection controls)
 {
  foreach (Control item in controls)
  {
   //服務器TextBox
   if (item.GetType() == typeof(System.Web.UI.WebControls.TextBox))
   {
    WebControl webControl = item as WebControl;
    webControl.Attributes.Add("onkeydown", "if(event.which || event.keyCode){if ((event.which == 13) || (event.keyCode == 13)) {return false;}} ");
   }
   //html控件
   else if (item.GetType() == typeof(System.Web.UI.HtmlControls.HtmlInputText))
   {
    HtmlInputControl htmlControl = item as HtmlInputControl;
    htmlControl.Attributes.Add("onkeydown", "if(event.which || event.keyCode){if ((event.which == 13) || (event.keyCode == 13)) {return false;}} ");
   }
   //用戶控件
   else if (item is System.Web.UI.UserControl)
   {
    CancelFormControlEnterKey(item.Controls); //遞歸調用
   }
  }
 }
}

這樣,想取消“enter key”功能的頁面只有繼承一下BasePage類即可。

2、用戶控件的處理:我的思路就是在基類中繼續處理用戶控件內部的runat=server的控件,測試也是通過的。

3、頁面中和用戶控件里的沒有runat=server標簽的html控件,直接給這些html控件添加onkeydown事件。

下面是測試頁面和其對應的類文件:

Test.aspx頁面:

%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Test.aspx.cs" Inherits="Test" %>
%@ Register src="TestUserControl.ascx" tagname="TestUserControl" tagprefix="uc1" %>
!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
html xmlns="http://www.w3.org/1999/xhtml">
head runat="server">
 title>/title>
/head>
body>
 form id="form1" runat="server" >
input type=text id="txtTest" runat="server" /> input id="txtTest1" type="text" name="txtTest1" onkeydown="if(event.which || event.keyCode){if ((event.which == 13) || (event.keyCode == 13)) {return false;}}" /> 
asp:textbox ID="Textbox1" runat="server">/asp:textbox>
 uc1:TestUserControl ID="TestUserControl1" runat="server" />
asp:Button ID="btnSubmit" runat="server" Text="Submit" />
 /form>
/body>
/html>

類:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
public partial class Test : BasePage
{
 protected void Page_Load(object sender, EventArgs e)
 {
  Response.Write("123");
 }
}

接著是一個用戶控件:

%@ Control Language="C#" AutoEventWireup="true" CodeBehind="TestUserControl.ascx.cs" Inherits="MyWeb.TestUserControl" %>
asp:TextBox ID="TextBox1" runat="server">/asp:TextBox>
br />
input id="Text1" type="text" runat="server"/>
br />
input id="txtInput" type="text" name="txtInput" onkeydown="if(event.which || event.keyCode){if ((event.which == 13) || (event.keyCode == 13)) {return false;}}" />

在筆者的機器上,對TextBox,HtmlInputText和沒有runat=server標簽的html控件以及三者組合成的用戶控件按照上面的思路按下enter鍵運行效果果然沒有回發了。

二、腳本改進時碰到的問題

然后我看到if(event.which || event.keyCode){if ((event.which == 13) || (event.keyCode == 13)) {return false;}}這一句不斷地出現,就好心把它在頁面里封裝成JavaScript函數叫forbidInputKeyDown(ev):

script type="text/javascript">
 function forbidInputKeyDown(ev) {
  if (typeof (ev) != "undefined") {
   if (ev.keyCode || ev.which) {
    if (ev.keyCode == 13 || ev.which == 13) { return false; }
   }
  }
 }
/script>

然后onkeydown的方法對應的事件就是“forbidInputKeyDown(event)”(比如對于頁面中服務器端的TextBox控件在注冊客戶端事件的時候就改寫成 webControl.Attributes.Add("onkeydown", "forbidInputKeyDown(event)");),奇怪的是,這一次,頁面又回發了?! 然后腳本調試,forbidInputKeyDown函數也執行了,可是form還是被提交了。

我又看了一下腳本位置,把它從head移動到body內,問題依舊。然后懷疑是不是腳本錯了?不對,腳本沒錯。難道是人品有問題?有問題嗎,這個自信真沒有。注冊事件錯了嗎?嗯......

我kao,恍然大悟,注冊事件應該這么寫的:onkeydown="return forbidInputKeyDown(event)",也就是forbidInputKeyDown函數前面加上return就好了,還是人品啊,囧。

希望本文所述對大家asp.net#程序設計有所幫助。

您可能感興趣的文章:
  • ASP.NET中 TextBox 文本輸入框控件的使用方法
  • C#自定義IP輸入框控件

標簽:吉林 宜春 河南 婁底 汕頭 重慶 麗江 本溪

巨人網絡通訊聲明:本文標題《asp.net實現取消頁面表單內文本輸入框Enter響應的方法》,本文關鍵詞  asp.net,實現,取消,頁面,表,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《asp.net實現取消頁面表單內文本輸入框Enter響應的方法》相關的同類信息!
  • 本頁收集關于asp.net實現取消頁面表單內文本輸入框Enter響應的方法的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    男女男精品视频网| 天天综合色天天综合| av在线这里只有精品| 久久婷婷国产综合精品青草| 国产永久精品大片wwwapp| 久久蜜桃av一区精品变态类天堂| 国产毛片一区二区| 中文字幕中文字幕在线一区 | 国产麻豆日韩欧美久久| 国产性天天综合网| 波多野结衣亚洲| 一二三区精品视频| 日韩一区二区高清| 国产成人在线观看免费网站| 亚洲欧洲美洲综合色网| 欧美久久久久免费| 国产自产2019最新不卡| 亚洲视频一区二区免费在线观看| 欧美日韩在线直播| 久88久久88久久久| 综合久久综合久久| 欧美一区二区三区播放老司机| 国产精品自拍毛片| 亚洲国产综合色| 欧美精品一区二区三区很污很色的| a4yy欧美一区二区三区| 日日夜夜精品免费视频| 国产精品久久久久久久久免费桃花| 欧美大片顶级少妇| 99久久精品99国产精品 | 久久国产精品露脸对白| 日韩欧美中文字幕一区| av中文字幕在线不卡| 五月天网站亚洲| 中文字幕一区二区三区在线不卡 | 欧美日韩一区二区在线观看视频| 精品一区二区在线看| 亚洲欧美激情视频在线观看一区二区三区| 欧美日韩精品一区二区在线播放| 国产精品1区2区3区| 香蕉成人伊视频在线观看| 欧美国产日韩亚洲一区| 欧美一区二区女人| 日本精品一区二区三区四区的功能| 韩国成人福利片在线播放| 亚洲三级在线播放| 久久久精品免费免费| 欧美酷刑日本凌虐凌虐| 91小视频免费看| 国产激情91久久精品导航| 免费成人在线网站| 亚洲第一成人在线| 亚洲自拍与偷拍| 椎名由奈av一区二区三区| 久久免费偷拍视频| 精品日本一线二线三线不卡| 538prom精品视频线放| 日本高清成人免费播放| 99re这里只有精品6| 国产二区国产一区在线观看| 开心九九激情九九欧美日韩精美视频电影 | 1024成人网色www| 日韩欧美中文字幕制服| 欧美一卡二卡在线观看| 欧美女孩性生活视频| 欧美日韩视频在线一区二区| 91极品视觉盛宴| 在线视频一区二区三| 91国产精品成人| 一本大道综合伊人精品热热| 99精品久久久久久| 色香蕉久久蜜桃| 欧美在线观看视频一区二区三区| 色综合久久九月婷婷色综合| 91色porny在线视频| 99视频精品在线| 91网上在线视频| 欧美伊人精品成人久久综合97| 色老汉一区二区三区| 在线观看亚洲一区| 欧美放荡的少妇| 欧美大度的电影原声| 久久亚洲综合色一区二区三区| 日韩精品一区二区三区在线播放 | 国产农村妇女毛片精品久久麻豆| 久久精品亚洲精品国产欧美kt∨ | 国产美女精品人人做人人爽| 国内精品写真在线观看 | gogo大胆日本视频一区| a亚洲天堂av| 在线视频国内一区二区| 欧美日韩一二区| 日韩精品资源二区在线| 久久综合网色—综合色88| 国产午夜精品久久久久久久| 成人免费在线播放视频| 亚洲午夜私人影院| 免播放器亚洲一区| 国产999精品久久久久久| 色老综合老女人久久久| 91精品免费在线| 久久久精品蜜桃| 一区二区三区不卡视频在线观看| 无码av免费一区二区三区试看| 日本在线不卡一区| 国产成人av电影免费在线观看| 91免费在线视频观看| 欧美性色黄大片| 精品日韩一区二区三区| 国产精品电影院| 日韩主播视频在线| 国产suv精品一区二区883| 欧美午夜影院一区| 久久一区二区视频| 国产精品久久久久久久午夜片| 日本欧洲一区二区| 成人免费视频一区| 欧美日韩一区二区在线视频| 国产亚洲精品超碰| 日韩在线一二三区| 国产 日韩 欧美大片| 在线播放中文字幕一区| 国产午夜精品一区二区| 亚洲高清免费观看高清完整版在线观看| 美女久久久精品| 91香蕉视频在线| 久久先锋资源网| 日韩精品免费视频人成| 91同城在线观看| 久久精品一区八戒影视| 人禽交欧美网站| 欧洲激情一区二区| 国产精品福利av| 国产成人免费高清| 欧美一区二区三区在线观看视频 | 日韩免费一区二区| 一区二区三区中文字幕电影 | 久久99最新地址| 欧美日韩视频不卡| 亚洲精品成人悠悠色影视| 国产精品亚洲第一区在线暖暖韩国| 欧美精品v日韩精品v韩国精品v| 中文字幕综合网| 成人深夜在线观看| 欧美精品一区二区三| 日本成人在线电影网| 欧美群妇大交群的观看方式| 亚洲另类在线视频| 91在线码无精品| 国产精品国产a| 成人三级在线视频| 国产精品美女久久久久aⅴ| 国产一区二区在线影院| 欧美大胆一级视频| 久久激情五月婷婷| 欧美成人精品1314www| 美腿丝袜亚洲一区| 欧美大片一区二区三区| 蜜桃91丨九色丨蝌蚪91桃色| 欧美一区二视频| 男男视频亚洲欧美| 欧美一区二区福利在线| 男女男精品视频网| 911精品产国品一二三产区| 亚洲国产裸拍裸体视频在线观看乱了| av毛片久久久久**hd| 中文字幕一区二区日韩精品绯色| 成人短视频下载| 亚洲情趣在线观看| 欧美色视频在线| 日韩电影在线观看一区| 日韩欧美一区电影| 黄网站免费久久| 国产日本欧洲亚洲| av一区二区三区在线| 一区二区三区在线观看动漫| 欧美制服丝袜第一页| 天天综合色天天综合色h| 欧美一级免费观看| 国产在线乱码一区二区三区| 欧美激情一区二区在线| 99久久久免费精品国产一区二区| 亚洲欧美激情插| 91精品在线免费| 国产传媒日韩欧美成人| 亚洲日本在线a| 欧美肥胖老妇做爰| 麻豆精品一区二区三区| 久久人人超碰精品| 一本久久a久久免费精品不卡| 亚洲.国产.中文慕字在线| 日韩女优av电影| 91影视在线播放| 日本系列欧美系列| 国产日本一区二区| 欧美亚洲图片小说| 国产麻豆视频一区二区| 亚洲人成亚洲人成在线观看图片| 欧美日韩和欧美的一区二区| 国产在线精品视频|