设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 762|回复: 5
打印 上一主题 下一主题

[其它] [原创][新手上路]选取录入高频使用词条

[复制链接]
跳转到指定楼层
1#
发表于 2004-8-2 23:54:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
对于某些词语,可能在录入时经常用到,它可能是字段值的其中某一部分,而不适宜于组合框或者列表框,用高频词条选区录入窗,可较好解决此问题。

对于新手来说,此范例主要用到以下几个知识点:

1。全局的功能键定义。 见附件的  autokeys 宏

2。用Screen.ActiveCtontrol 来得到当前获得焦点的控件,而不必关心他所在窗体。

3。窗体之间的传值,实际上这里相当于控件之间的传值。

4。在文本框的光标处,插入字符。实际上是文本框SelStart和SelLength的应用。只有获得焦点的文本框才有此属性。



主要功能代码预览:

' 定义公共变量

Public gctlInputCommonuseCalled As Control      '调用窗体的控件

Public gintCtlCalledSelStart As Integer     '当前光标位置

Public gintCtlCalledSellength As Integer    '选取文本长度



'打开高频词选区窗体

Public Function gInputCommonUseString() As String

    On Error Resume Next

    Const cstrFormName = "frmpubselectIncommonuse"

    Const cstrCtlName = "list0"

    If Not CurrentProject.AllForms(cstrFormName).IsLoaded Then

        '如果窗体是关闭的,那么打开窗体

        

        Set gctlInputCommonuseCalled = Screen.ActiveControl     '获取当前控件

        If gctlInputCommonuseCalled Is Nothing Then

            Exit Function

        Else

            '写入相关属性到变量

            gintCtlCalledSelStart = gctlInputCommonuseCalled.SelStart

            gintCtlCalledSellength = gctlInputCommonuseCalled.SelLength

            

            '保存修改,否则可能插入错误值(就是控件的旧值)

            DoCmd.RunCommand acCmdSaveRecord

            

            '打开窗体

            DoCmd.OpenForm cstrFormName

        End If

    Else

        '否则,窗体是打开的,则返回窗体的值

        

        If IsNull(gctlInputCommonuseCalled.Value) Or gctlInputCommonuseCalled.ControlType <> acTextBox Then

            '如果控件的值为空,这不是文本框,则直接赋值为选定的词条

            gctlInputCommonuseCalled.Value = Forms(cstrFormName).Controls(cstrCtlName).Value

        Else

            '否则,在光标位置插入选定的词条

            gctlInputCommonuseCalled.Value = Left$(gctlInputCommonuseCalled.Value, gintCtlCalledSelStart) & _

                                             Forms(cstrFormName).Controls(cstrCtlName).Value & _

                                             Mid$(gctlInputCommonuseCalled.Value, gintCtlCalledSellength + gintCtlCalledSelStart + 1)

        End If

        

        Err.Clear

        '关闭窗体

        DoCmd.Close acForm, cstrFormName

    End If

End Function

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
发表于 2002-11-1 18:33:00 | 只看该作者
笑死我了
3#
发表于 2002-11-1 19:07:00 | 只看该作者
看过了!!
4#
发表于 2002-11-2 00:10:00 | 只看该作者
朋友的爸爸叫"鄭開支",他說:唉!現在經濟不景氣",故他的孫要取名為"鄭收入"
同學叫"吳德章",很多公眾活動都沒他份 ,因為個個叫他"吳得獎"
同事叫"李發達",他說從來借不到錢!

5#
发表于 2004-11-24 05:00:00 | 只看该作者
很不错!
6#
发表于 2004-11-24 16:04:00 | 只看该作者
没看懂。。。按F8 出现了错误~~支持
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-11 01:41 , Processed in 0.083454 second(s), 30 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表