微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

VB.NET之旅—文本框内字符串的检验(机房收费系统重构个人版)

如果大家的机房收费已经敲了一段时间了,尤其是敲了注册,那么大家一定遇到了文本框内字符串检验的问题,大家对字符串检验感到厌烦吗?

既然感到厌烦,那么就应该寻找简单的方法,如果你还是用messageBox提示用户输入信息错误地话,那么我说你已经过时了,高大上的软件,都是这么提示信息的:

我们虽然不能做到这么洋气,但是还是可以不断靠拢吗?例如可以做到这样

这样:


我把文本框内的字符串检验分为四步

  1. 去除字符串左右的空格
  1. 检验字符串是否为空
  1. 检验字符串是否符合要求
  2. 提示字符串符合要求
代码如下:
#Region "检验文本框字符串是否符合要求四部曲"

    '1-----去除文本左右两边的空格
    Public Function ClearSpace(ByVal txtBox As TextBox)
        Return txtBox.Text.ToString.Trim()
    End Function

    '2-----**不能为空
    Public Sub notEmpty(ByVal txtBox As TextBox,ByVal lbl1 As Label,ByVal lbl2 As Label)
        Dim x As Int16 = lbl2.Text.ToString.Trim.Length - 1 '设置字符串长度为减一,以去掉冒号
        lbl1.ForeColor = Color.Red
        lbl1.Text = lbl2.Text.Substring(0,x) & ",不能为空"
        txtBox.Focus()
    End Sub

    '3------字符串不符合要求
    Public Sub notMatch(ByVal txtBox As TextBox,ByVal lbl As Label,ByVal reminder As String)
        lbl.ForeColor = Color.Red
        lbl.Text = reminder
        txtBox.Focus()
        txtBox.SelectAll()
    End Sub

    '4-----文本框输入正确
    Public Sub Correct(ByVal lbl As Label)
        lbl.ForeColor = Color.Green
        lbl.Text = "√"
    End Sub
#End Region

我们接下来看一下调用过程:

  '验证用户名是否为空和验证此用户是否存在
  Public Sub IsNameRight()
    If ClearSpace(Me.txtName) = "" Then
      notEmpty(Me.txtName,Me.lblUserName,Me.lblUserName1)
      Exit Sub
    Else
      username = txtName.Text.ToString.Trim


      admininfo1 = manager.selectAdmin_info(username)
      If admininfo1 Is nothing Then
        notMatch(Me.txtName,"用户名错误")


        Exit Sub
      Else


        Correct(Me.lblUserName)
      End If
    End If
  End Sub




  Private Sub txtName_LostFocus(ByVal sender As Object,ByVal e As System.EventArgs) Handles txtName.LostFocus
    IsNameRight()
  End Sub

这样是不是省了不少事啊,例如对

txtBox.Focus()

txtBox.SelectAll()

的不断重复书写,呵呵,大家不妨尝试一下!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强制返回为文本 -------------------------------- 数字类型的格式化 --------------------------------     固定格式参数:     General Number 普通数字,如可以用来去掉千位分隔号     format$("100,1
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办法, Format 或者FormatDateTime 竟然结果和系统设置的区域语言的日期和时间格式相关。意思是尽管你用诸如 Format(Now, "MM/dd/yyyy"),如果系统的设置格式区域语言的日期和时间格式分隔符是"-",那他还会显示为 MM-dd-yyyy     只有拼凑: <%response.write
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace My ‘全局错误处理,新的解决方案直接添加本ApplicationEvents.vb 到工程即可 ‘添加后还需要一个From用来显示错误。如果到这步还不会则需要先打好基础啦 ‘======================================================== ‘以下事件
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用的爽呀,这篇文章写与2011年,看来我以前没有认真去找这个方法呀。 https://blog.csdn.net/chzjxgd/article/details/6176325 金蝶K3 BOS的插件官方是用VB6编写的,如果  能用.Net下的语言工具开发BOS插件是一件很愉快的事情,其中缘由不言而喻,而本文则是个人首创,实现在了用V
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选中的单元格进行处理 Dim m As Range, tmpStr As String, s As String Dim x As Integer, y As Integer, subStr As String If MsgBox("确定要分列处理吗?请确定分列的数据会覆盖它后面的单元格!", _
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, X As Single, Y As Single) 2 Dim path As String, hash As String 3 For Each fil
  Imports MySql.Data.MySqlClient Public Class Form1 ‘ GLOBAL DECLARATIONS Dim conString As String = "Server=localhost;Database=net2;Uid=root;Pwd=123456;" Dim con As New MySqlConnection
‘導入命名空間 Imports ADODB Imports Microsoft.Office.Interop   Private Sub A1() Dim Sql As String Dim Cnn As New ADODB.Connection Dim Rs As New ADODB.Recordset Dim S As String   S = "Provider=OraOLEDB.Oracl
Imports System.IO Imports System.Threading Imports System.Diagnostics Public Class Form1 Dim A(254) As String    Function ping(ByVal IP As Integer) As String Dim IPAddress As String IPAddress = "10.0.
VB运行EXE程序,并等待其运行结束 参考:https://blog.csdn.net/useway/article/details/5494084 Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long Pr