如何解决KeyDown 事件:vbKeyUp、vbKeyDown 在不失去字段焦点的情况下增加表单中的日期字段
我有一个很小的代码正在使用 vbKeyUp 或 Down 来增加日期字段 (SaleDate)。如何将焦点保持在 Field SaleDate 中?目前,UpArrow up 键将日期递减一天,并将焦点更改为前一个字段。 DownArrow 键增加日期,但将焦点移到下一条记录。在这两种情况下,我都希望能够按一次或多次键将日期更改一天或多天。
Private Sub SaleDate_KeyDown(KeyCode As Integer,Shift As Integer)
Select Case KeyCode
Case vbKeyUp
'MsgBox "UP"
Me.SaleDate = Me.SaleDate - 1
Case vbKeyDown
'MsgBox "DOWN"
Me.SaleDate = Me.SaleDate + 1
End Select
End sub
解决方法
你就快到了,只是:
通过将 KeyCode 设置为 0 来抑制按键的正常功能:
Private Sub SaleDate_KeyDown(KeyCode As Integer,Shift As Integer)
Select Case KeyCode
Case vbKeyUp
'MsgBox "UP"
Me.SaleDate = Me.SaleDate - 1
KeyCode = 0
Case vbKeyDown
'MsgBox "DOWN"
Me.SaleDate = Me.SaleDate + 1
KeyCode = 0
End Select
End sub
并在设计窗格中将 Form.KeyPreview
属性设置为 True
,以确保您的代码在标准效果之前触发,而不是之后触发。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。