以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  DateTimePicker控件,有办法做到输入日期,自动把所在年月填上  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=96271)

--  作者:szsmall
--  发布时间:2017/2/16 19:51:00
--  DateTimePicker控件,有办法做到输入日期,自动把所在年月填上
DateTimePicker控件,有办法做到输入日期,自动把年月填上。例如今天是2017-02-16,只需填入16,就自动显示2017-02-16
--  作者:有点色
--  发布时间:2017/2/16 21:13:00
--  

TextChanged事件

 

If e.sender.Text.length = 2 Then
    e.Sender.value = new Date(Date.Today.Year, Date.Today.Month, val(e.sender.text))
End If


--  作者:szsmall
--  发布时间:2017/2/17 11:04:00
--  
如果误输35(2月只有28天,超过月份的天数),就会出现下面的错误。

.NET Framework 版本:2.0.50727.3053
Foxtable 版本:2016.7.29.1
错误所在事件:窗口,例子二停靠,DateTimePicker1,Leave
详细错误信息:
Year, Month, and Day parameters describe an un-representable DateTime.


--  作者:有点色
--  发布时间:2017/2/17 11:07:00
--  
If e.sender.Text.length = 2 Then
    If val(e.sender.Text) <= Date.DaysInMonth(Date.today.Year, Date.Today.Month) Then
        e.Sender.value = new Date(Date.Today.Year, Date.Today.Month, val(e.sender.text))
    End If
End If

--  作者:szsmall
--  发布时间:2017/2/17 11:51:00
--  
leave事件

If val(e.sender.Text) <= Date.DaysInMonth(Date.today.Year, Date.Today.Month) Then
    If e.sender.Text.length = 1 Then
        e.Sender.value = new Date(Date.Today.Year, Date.Today.Month, val(e.sender.text))
    ElseIf e.sender.Text.length = 2 Then
        e.Sender.value = new Date(Date.Today.Year, Date.Today.Month, val(e.sender.text))
    End If
Else
    e.sender.Select
End If


如果超过31天,返回控件,用e.sender.Select,不知道对不对


--  作者:有点色
--  发布时间:2017/2/17 11:59:00
--  
代码测试没问题。有什么问题?
--  作者:szsmall
--  发布时间:2017/2/20 1:16:00
--  
要把“e.sender.Select”去掉,不然用鼠标选择日期时,焦点会一直在日期空间上,界面会锁住。

去掉后,发现日期输错,控件本身也会提示错误
[此贴子已经被作者于2017/2/27 12:47:00编辑过]

--  作者:有点色
--  发布时间:2017/2/20 9:17:00
--  

改一下

 

If e.sender.text.length <= 2 Then
    If val(e.sender.Text) <= Date.DaysInMonth(Date.today.Year, Date.Today.Month) Then
        If e.sender.Text.length = 1 Then
            e.Sender.value = new Date(Date.Today.Year, Date.Today.Month, val(e.sender.text))
        ElseIf e.sender.Text.length = 2 Then
            e.Sender.value = new Date(Date.Today.Year, Date.Today.Month, val(e.sender.text))
        End If
    Else
        e.sender.Select
    End If
End If