问题描述
我有一个很小的代码正在使用 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
,以确保您的代码在标准效果之前触发,而不是之后触发。