以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  像excel 单元格 录入 记忆 怎么做  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=110001)

--  作者:ljh29206
--  发布时间:2017/11/24 10:54:00
--  像excel 单元格 录入 记忆 怎么做
之前有看过相关帖子,没找到

求助

例如 表中有数据列 为 : 名称   其中单元格数值为  LBHC

我在控件 TextBox  上  录入 L 之母后,   后边能够涂黑显示BHC,但不妨碍我继续录入.

这个效果怎么做?

--  作者:有点甜
--  发布时间:2017/11/24 12:09:00
--  

textchanged事件

 

If e.Sender.text > "" Then
    systemready = False
    Dim idx As Integer = e.Sender.SelectionStart
    Dim fdr As DataRow = DataTables("表A").find("第一列 like \'" & e.sender.Text.SubString(0,idx) & "%\'")
    If fdr IsNot Nothing Then
        e.sender.text = fdr("第一列")
        e.Sender.SelectionStart = idx
        e.Sender.SelectionLength = e.Sender.Text.length-idx
    End If
    systemready = True
End If

 

keydown事件

 

If e.KeyCode = keys.delete Then
    Dim idx As Integer = e.sender.SelectionStart
    Dim str = left(e.sender.text, idx)
    str &= right(e.sender.text, e.sender.text.length-idx-e.Sender.SelectionLength)
    Systemready = False
    e.sender.text = str
    e.sender.SelectionStart = idx
    Systemready = True
ElseIf e.KeyCode = Keys.Back Then
    If e.sender.SelectionLength > 0 Then
        Dim idx As Integer = e.sender.SelectionStart
        Dim str = left(e.sender.text, idx-1)
        str &= right(e.sender.text, e.sender.text.length-idx-e.Sender.SelectionLength)
        Systemready = False
        e.sender.text = str
        If e.sender.text > "" Then
            e.sender.SelectionStart = idx
            Dim fdr As DataRow = DataTables("表A").find("第一列 like \'" & e.sender.Text & "%\'")
            If fdr IsNot Nothing Then
                e.sender.text = fdr("第一列")
                e.Sender.SelectionStart = str.length
                e.Sender.SelectionLength = e.Sender.Text.length-str.length
            End If
        End If
        systemready = True
        e.cancel = True
    End If
End If