您现在的位置是:首页 > cms教程 > Discuz教程Discuz教程
Discuz的NT控件剖析TextBox
春翠2025-06-28Discuz教程已有人查阅
导读继上篇文章之后大家给了不少的反馈,其中有肯定也有否定的,必定程序设计有很多个性化的东西,因此就会有不同的意见产生。
继上篇文章之后大家给了不少的反馈,其中有肯定也有否定的,必定程序设计有很多个性化的东西,因此就会有不同的意见产生。我会从中找出合理化的意见并纠正以往认识和设计思路上的错误。希望大
家能一如既往的支持我们的这个开源项目。好了,开始今天的话题,今天就说一下 TextBox 控件。
先贴一张运行效果图让大家看一下:
开发动机:早在上一家公司时,就有了这个控件的开发想法并设计了一个简单的“原型”。在加入Discuz之后,因为要在后台管理设计用使用客户端JS校验,因此就在原有的代码基本上进行了相应
的扩充,添加了如正规订制,较大长度限制等功能。当前的这个代码是1.0版本中的源码。
其实看过我们这个代码的人应该很容易看出这个控件是采用控件复合方式完成的。里面的几个控
件定义如下:
它们绑定的函数就是SetValiateControls(),现说明如下:
校验时有效。而Text属性中的日期格式强制转换主要为了避免不同语言操作系统,数据库日期格式不同才这样操作的。
存在的问题:firefox 下的校验js无法使用。
程序逻辑结构还有待优化。
选项中出现中文,数据校验,电子邮箱等(以后会采用英文)
如果ie下 js 无法使用可运行“开始” - “运行” -- 输入“cmd” 然后执行
C:/windows/Microsoft.Net/Framework/v1.1.4322/aspnet_regiis -c 即可
家能一如既往的支持我们的这个开源项目。好了,开始今天的话题,今天就说一下 TextBox 控件。
先贴一张运行效果图让大家看一下:
开发动机:早在上一家公司时,就有了这个控件的开发想法并设计了一个简单的“原型”。在加入Discuz之后,因为要在后台管理设计用使用客户端JS校验,因此就在原有的代码基本上进行了相应
的扩充,添加了如正规订制,较大长度限制等功能。当前的这个代码是1.0版本中的源码。
其实看过我们这个代码的人应该很容易看出这个控件是采用控件复合方式完成的。里面的几个控
件定义如下:
System.Web.UI.WebControls.TextBox tb=new System.Web.UI.WebControls.TextBox();
System.Web.UI.WebControls.RequiredFieldValidator RequiredFieldValidator1=new RequiredFieldValidator();
System.Web.UI.WebControls.RegularExpressionValidator RegularExpressionValidator1=new RegularExpressionValidator();
System.Web.UI.WebControls.RangeValidator rangevalidator=new System.Web.UI.WebControls.RangeValidator();
其中的tb就是这个控件的主角,客户端所呈现的文件框就是它, RequiredFieldValidator1用户是否强制输入内容的控件(与tb进行绑定),而RegularExpressionValidator1则是将系统正则式或用户定制的正则式进行初始化并与tb进行绑定和控制的控件。rangevalidator则是进行范围限制的控件。它们绑定的函数就是SetValiateControls(),现说明如下:
1SetValiateControls()
2{
3
4 this.Controls.Add(tb); 向自定控件中加入tb(TextBox)控件
5
6 //当有要进行正则校验的设置时
7 if((RequiredFieldType!=null)&&(RequiredFieldType!="")&&(RequiredFieldType!="暂无校验"))
8 {
9 //设置显示信息方式为 "Dynamic"
10 RegularExpressionValidator1.Display=System.Web.UI.WebControls.ValidatorDisplay.Dynamic;
11 //将textbox与RegularExpressionValidator1校验控件相绑定
12 RegularExpressionValidator1.ControlToValidate=tb.ID;
13 //根据校验类型加载相应的正则式
14 switch (RequiredFieldType)
15 {
16 case "数据校验":
17 {
18 //如有用户定制的正则式则使用,如没有则使用系统自带的正则式
19 RegularExpressionValidator1.ValidationExpression=(this.ValidationExpression!=null)?
20 this.ValidationExpression:"^[-]?\\d+[.]?\\d*$";
21 //绑定错误信息
22 RegularExpressionValidator1.ErrorMessage="数字的格式不正确";break;
23 }
24
25
26 //是否可以不输入内容的判断
27 switch (CanBeNull)
28 {
29 case "可为空": { break; }
30 case "必填":
31 {
32 //当必填时则进行RequiredFieldValidator1的设置和tb的绑定
33 RequiredFieldValidator1.Display=System.Web.UI.WebControls.ValidatorDisplay.Dynamic;
34 RequiredFieldValidator1.ControlToValidate=tb.ID;
35 RequiredFieldValidator1.ErrorMessage="<font color=red>请务必输入内容!</font>";
36 this.Controls.Add(RequiredFieldValidator1);
37 break;
38 }
39 default : { break; }
40 }
41
42 }
下面依次说明其它主要属性和功能:
1SetFocusButtonID属性用户当用户在tb控件中输入回车符时相应获得焦点的控件ID(一般是“提交”按钮的ID值),
2相关代码如下:
3 [Bindable(true),Category("Appearance"),DefaultValue("")]
4 public string SetFocusButtonID
5 {
6 get
7 {
8 object o = ViewState[this.ClientID+"_SetFocusButtonID"];
9 return (o==null)?"":o.ToString();
10 }
11 set
12 {
13 ViewState[this.ClientID+"_SetFocusButtonID"] = value;
14 if(value!="")
15 {
16 tb.Attributes.Add("onkeydown","if(event.keyCode==13){
17 document.getElementById('"+value+"').focus();}");
18 }
19 }
20 }
21
22
23 //为tb控件设置内容较大长度属性,注当为多行“MultiLink”(即:textarea)时,会使用JS得到获取该属性进行长度的检查
24 [Bindable(true),Category("Appearance"),DefaultValue("")]
25 public int MaxLength
26 {
27 get
28 {
29 object o =ViewState["TextBox_MaxLength"];
30 if(o!=null)
31 {
32 int maxlength= Convert.ToInt32(o.ToString());
33 AddAttributes("maxlength",maxlength.ToString());
34 return maxlength;
35 }
36 else
37 {
38 return -1;
39 }
40 }
41 set
42 {
43 ViewState["TextBox_MaxLength"] = value;
44 AddAttributes("maxlength",value.ToString());
45 }
46 }
47
48
49 //控件的TextMode属性,用于定制显示模式为“密码,单行或多行”
50 [Bindable(false),Category("Behavior"),DefaultValue(""),TypeConverter(
51 typeof(TextModeFieldTypeControlsConverter)),Description("要滚动的对象。")]
52 public string TextMode
53 {
54 get
55 {
56 return tb.TextMode.ToString();
57 }
58 set
59 {
60 if (value=="Password") tb.TextMode =TextBoxMode.Password;
61 if (value=="MultiLine")
62 {
63 tb.TextMode =TextBoxMode.MultiLine;
64 tb.Attributes.Add("onkeyup","return isMaxLen(this)");
65 }
66 if (value=="SingleLine") tb.TextMode =TextBoxMode.SingleLine;
67 }
68 }
69
70 //设置校验类型, 并初始化控件绑定
71 [Bindable(false),Category("Behavior"),DefaultValue(""),TypeConverter(typeof(
72 RequiredFieldTypeControlsConverter)),Description("要滚动的对象。")]
73 public string RequiredFieldType //要进行校验的表达式
74 {
75 get
76 {
77 object o = ViewState["RequiredFieldType"];
78 return (o==null)?"":o.ToString();
79 }
80 set
81 {
82 ViewState["RequiredFieldType"] = value;
83 //初始化控件绑定,此处代码调用先后逻辑还存在一些问题,已在2.0版本做相应修正。
84 SetValiateControls();
85 }
86 }
87
88 .
89
90
91 //采用下拉框显示方式来显示校验类型,如图:
92 public class RequiredFieldTypeControlsConverter:StringConverter
93 {
94 public RequiredFieldTypeControlsConverter() {}
95
96 public override bool GetStandardValuesSupported(ITypeDescriptorContext context)
97 {
98 return true;
99 }
100
101 public override System.ComponentModel.TypeConverter.StandardValuesCollection GetStandardValues(
102 ITypeDescriptorContext context)
103 {
104 ArrayList controlsArray = new ArrayList();
105 controlsArray.Add("暂无校验");
106 controlsArray.Add("数据校验");
107 controlsArray.Add("电子邮箱");
108 controlsArray.Add("移动手机");
109 controlsArray.Add("家用电话");
110 controlsArray.Add("身份证号码");
111 controlsArray.Add("网页地址");
112 controlsArray.Add("日期");
113 controlsArray.Add("日期时间");
114 controlsArray.Add("金额");
115 controlsArray.Add("IP地址");
116 controlsArray.Add("IP地址带端口");
117 return new StandardValuesCollection(controlsArray);
118 }
119
120 public override bool GetStandardValuesExclusive(ITypeDescriptorContext context)
121 {
122 return false;
123 }
124 }
这样就完成了这个控件的主干部分,而其它的一些属性,如MaximumValue(较大值),MinimumValue(小值)仅在进行数据校验时有效。而Text属性中的日期格式强制转换主要为了避免不同语言操作系统,数据库日期格式不同才这样操作的。
存在的问题:firefox 下的校验js无法使用。
程序逻辑结构还有待优化。
选项中出现中文,数据校验,电子邮箱等(以后会采用英文)
如果ie下 js 无法使用可运行“开始” - “运行” -- 输入“cmd” 然后执行
C:/windows/Microsoft.Net/Framework/v1.1.4322/aspnet_regiis -c 即可
本文标签:
很赞哦! ()
上一篇:如何一键安装Discuz Q
下一篇:discuz插件制作方法步骤流程
相关教程
- FolderPainter
- ContextMenuManager
- JavaScript数字的toExponential()方法
- JavaScript Number.parseInt()方法:将字符串解析为整数
- JavaScript Number.isInteger()方法:精确判断整数类型
- JavaScript Proxy的preventExtensions:对象锁定机制的精确保留
- JavaScript Map entries()方法
- JavaScript addEventListener
- Print Distributor
- Style2Paints
- JavaScript document.getElementsByTagName()
- document.getElementsByName()
图文教程
discuz版本号信息修改方法介绍
建完网站后,就到了改动discuz!论坛的步骤了,,将其改动为自己喜欢的样子。是非常有意思的,废话不多说了。以下给大家介绍改动的方法。
discuz模版学习教程
Discuz的模板采用近似PHP表达式的语法,支持的元素如下:逻辑元素包围符,该符号用于包含条件和循环元素第一次看到我还以为是注释的效果,后来才知道自己想得太天真了-_-!
Discuz!NT生成模板执行方式
1、ASP.NET内联编码编译时间问题先说下我的一个试验:新建一个WebApplication工程,打开Default.aspx文件,删除除之外的内容。之后在它的下边添加如下代码:
Discuz的NT与asp.net整合的方法
由于项目需要一个论坛,本来有CS的,在.net下很出名的国外开源论坛。但为了适应国内的风气,之后选用在国内如日中天的Discuz!NT。
相关源码
-
(PC+WAP)安保服务保安保镖模板免费下载本模板基于PbootCMS内核开发,为安保服务企业量身打造。设计风格严谨专业,突出安保行业的安全、可靠特性,展示企业服务项目与实力。采用响应式设计,PC与移动端数据同步,管理便捷。模板布局合理查看源码 -
帝国cms题库问答学习平台模板知识付费网站源码+数据采集为教育机构、培训平台及在线学习场景设计,提供完整的题库管理与问答服务解决方案。支持多种题型展示与答案查询,满足不同层次的学习需求。查看源码 -
(自适应响应式)WORDwps办公资源教程资讯网站模板下载基于PbootCMS内核开发的响应式网站模板,为办公教程、WPS技巧分享、职场技能培训等场景打造。模板内置标准化文档分类体系,支持图文/视频教程混合展示,满足现代办公知识传播需求。查看源码 -
(自适应响应式)html5蓝色智能水表营销型网站pbootcms模板下载PbootCMS内核开发,为智能水表企业打造的营销型网站解决方案,本模板基于PbootCMS内核开发,为智能水表及相关行业企业设计,采用HTML5+CSS3技术构建,具有响应式布局。查看源码 -
(自适应)html5宽屏电线电缆材料加工制造类企业网站源码下载本模板基于PbootCMS系统开发,特别适合电线电缆、电缆材料及相关加工制造类企业使用。采用HTML5宽屏设计,能够展示各类电缆产品的技术参数和规格详情,帮助客户全面了解产品特性。查看源码 -
(响应式H5)帝国cms7.5文章新闻博客模板带会员中心本模板基于帝国CMS内核开发,为新闻资讯、个人博客及作品展示类网站设计。采用响应式布局技术,确保在手机、平板和电脑等不同设备上都能获得良好的浏览体验。查看源码
| 分享笔记 (共有 篇笔记) |
