前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[自定义服务器控件] 第一步:文本框。

[自定义服务器控件] 第一步:文本框。

作者头像
用户1174620
发布2018-02-07 16:54:51
1.7K0
发布2018-02-07 16:54:51
举报

最近在整理我写的几个服务器控件,发出来与大家共享吧。

我写的自定义服务器控件呢分为两个类,

一是“简单继承”控件,就是继承框架里的控件然后加点属性了、事件了什么的。

二是“功能”控件,简单的说那是符合控件,但是呢是以实现一种功能为目的地。这种控件要实现某一种功能,比如分页的功能,添加、修改数据的功能,查询的功能。

原先呢还不会使用接口了什么的,所以呢代码写得有点不太“好看”,现在使用接口、继承了什么的来整理一下。

先发一个“文本框”的吧,就是继承系统的 TextBox,然后加上几个属性、方法。

属性:

TextTrim  返回.Text.Trim()

TextTrimNone 返回 .Text.Trim.Replace("'", "")

CheckDataType 设置 文本框的验证类型。

CheckDataReg  设置 文本框的验证用的正则表达式。

CheckErrorMessage 设置 当没有通过验证时显示给客户的提示信息。

属性(接口):

ControlKind  返回控件的类型。

函数(接口):

GetValue() 获取文本框的值,默认返回 TextTrim

GetValue(ByVal kind As String) 根据 kind 获取对应的文本框的值。

SetValue(ByVal value As String) 给文本框赋值

SetValue(ByVal value As String, ByVal kind As String)给文本框赋值

取值和赋值为什么会有两套呢?那是为了和其他控件兼容,说到后面就好理解了。

定义接口。

代码语言:javascript
复制
Public Interface IGetControlValue



    ReadOnly Property ControlKind() As String



    Function GetControlValue() As String

    Function GetControlValue(ByVal kind As String) As String



    Sub SetControlValue(ByVal value As String)

    Sub SetControlValue(ByVal value As String, ByVal kind As String)



End Interface

文本框的代码。

代码语言:javascript
复制
Imports System.ComponentModel

Imports System.Web.UI

Imports HBS



<DefaultProperty("Text"), ToolboxData("<{0}:HBSTextBox runat=server></{0}:HBSTextBox>")> _

 Public Class HBSTextBox

    Inherits System.Web.UI.WebControls.TextBox

    Implements INamingContainer

    Implements IGetControlValue



    Dim _dataType As String = ""   '数据类型



#Region "实现接口"

    <Bindable(True), Category("默认值"), DefaultValue(""), Description("获取控件类别")> _

       ReadOnly Property ControlKind() As String Implements IGetControlValue.ControlKind

        Get

            Return ""

        End Get

    End Property



    Public Function GetValue() As String Implements IGetControlValue.GetControlValue

        Return Me.TextTrimNone



    End Function



    Public Function GetValue(ByVal kind As String) As String Implements IGetControlValue.GetControlValue

        Return Me.TextTrimNone



    End Function



    Public Sub SetValue(ByVal value As String) Implements IGetControlValue.SetControlValue

        Me.Text = value



    End Sub



    Public Sub SetValue(ByVal value As String, ByVal kind As String) Implements IGetControlValue.SetControlValue

        Me.Text = value



    End Sub



#End Region



#Region "设置文本框的 Text 属性;获取 Text.Trim()"

    <Bindable(True), Category("文本值"), Description("设置文本框的 Text 属性;返回 Text.Trim()。")> _

    Property TextTrim() As String

        Set(ByVal Value As String)

            Me.Text = Value

        End Set

        Get

            Return Me.Text.Trim()

        End Get

    End Property

#End Region



#Region "设置文本框的 Text 属性;获取 Text.Trim()"

    <Bindable(True), Category("文本值"), Description("设置文本框的 Text 属性;返回 Text.Trim()。")> _

    Property TextTrimNone() As String

        Set(ByVal Value As String)

            Me.Text = Value

        End Set

        Get

            Return Me.Text.Trim.Replace("'", "")

        End Get

    End Property

#End Region





#Region "验证类型"

    <Category("数据验证"), Description("验证输入的内容,需要js脚本配合。"), DefaultValue("")> _

    Property CheckDataType() As String

        Set(ByVal Value As String)

            _dataType = Value

            '101        b不验证

            '102        z自然数

            '103        z整数

            '104        x小数

            '105        r日期

            '106        b必填

            Select Case Value

                Case "" '不验证

                    'this.Attributes.Add("DataType","");

                Case "" '自然数

                    Me.Attributes.Add("check", "^[0-9]+$")

                Case "" '整数

                    Me.Attributes.Add("check", "^\S?([0-9]+)$")

                Case "" '小数                [0-9]{1,5}\.[0-9]{1,2}  ^-?([0]$|^([0-9]{1,5}\.[0-9]{1,2})?$

                    Me.Attributes.Add("check", "^\S(\-?[0-9]*(\.[0-9]*)?)$")

                    'Me.Attributes.Add("check", "^d")

                Case "" '时间

                    Me.Attributes.Add("check", "^d{4}-d{1,2}-d{1,2}")

                Case "" '必填项

                    Me.Attributes.Add("check", ".+")

            End Select



        End Set

        Get

            If _dataType Is Nothing Then

                Return ""

            End If

            Return _dataType

        End Get

    End Property



    <Category("数据验证"), Description("验证输入的内容,传入正则表达式。"), DefaultValue("")> _

   Property CheckDataReg() As String

        Set(ByVal Value As String)

            Me.Attributes.Add("check", Value)

        End Set

        Get

            If Me.Attributes.Item("check") Is Nothing Then

                Return ""

            End If

            Return Me.Attributes.Item("check").ToString()

        End Get

    End Property





#End Region



#Region "验证错误的提示信息"

    <Description("验证错误提示信息")> _

      Property CheckErrorMessage() As String



        '添加提示信息

        Set(ByVal Value As String)

            ViewState("msg") = Value

            Me.Attributes.Add("warning", Value)

        End Set

        Get

            If (ViewState("msg") Is Nothing) Then

                Return ""

            Else

                Return ViewState("msg").ToString()

            End If

        End Get



    End Property

#End Region



    Protected Overrides Sub OnInit(ByVal e As EventArgs)

        If Not Me.CssClass Is Nothing Then

            Me.CssClass = "txts"

            Me.Attributes.Add("DataID", "")

            Me.Attributes.Add("DataIDs", "")

        End If



    End Sub





End Class

FAQ:

1、文本框的验证是如何实现的?

    使用正则表达式来验证,在具体点说呢就是使用了一个不知道是谁写一个js函数,就是 checkForm(oForm) 来验证的。

http://www.cnblogs.com/jyk/archive/2007/09/20/899406.html 这里有具体的说明。

2、为什么使用VB.net来写?

    很简单,好写。用VB.net写代码还是很方便的,也是很宽松的。好多在C#里不能通过编译的代码,在VB.net里面就可以正常使用,而且提示也是很“智能”的,当初刚写控件的时候还是不太熟悉,VB.net是很好的选择。

以后会陆续说明其他的控件。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2008-01-13 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档