设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

[窗体] 窗体的字段录入有效性设置问题

[复制链接]
跳转到指定楼层
1#
发表于 2013-9-24 09:55:55 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
请教各位老师,窗体字段在录入结束时如何自动检测全部字段已录入?即要求全部字段要有相应内容,不能有不填的空字段,如未填写某字段会有提示出现那一字段没有录入,请填写!先谢谢各位长期对我的支持!
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
发表于 2013-9-24 10:06:08 | 只看该作者
在字段属性设置不为空即可!
3#
发表于 2013-9-24 11:31:33 | 只看该作者
  1. Private Sub Form_BeforeUpdate(Cancel As Integer)
  2.     Dim ctl As Control
  3.     For Each ctl In Me.Controls
  4.         If TypeOf ctl Is TextBox Or TypeOf ctl Is ComboBox Then
  5.             If IsNull(ctl) Then
  6.                 MsgBox ctl.Name & "不可为空!"
  7.                 ctl.SetFocus
  8.                 Exit Sub
  9.             End If
  10.         End If
  11.     Next
  12. End Sub
复制代码
4#
发表于 2013-9-24 11:35:28 | 只看该作者
  1. Private Sub Form_BeforeUpdate(Cancel As Integer)
  2.     Dim ctl As Control
  3.     For Each ctl In Me.Controls
  4.         If TypeOf ctl Is TextBox Or TypeOf ctl Is ComboBox Then
  5.             If IsNull(ctl) Then
  6.                 MsgBox ctl.Name & "不可为空!"
  7.                 ctl.SetFocus
  8.                 Cancel = True
  9.                 Exit Sub
  10.             End If
  11.         End If
  12.     Next
  13. End Sub
复制代码
5#
 楼主| 发表于 2013-9-25 16:15:07 | 只看该作者

非常感谢“苹果”头老师!问题搞定了!谢谢!
6#
 楼主| 发表于 2013-9-25 16:16:47 | 只看该作者
access学习交流 发表于 2013-9-24 10:06
在字段属性设置不为空即可!

谢谢!没找到呀!模糊!
7#
发表于 2013-9-30 09:32:59 | 只看该作者
本帖最后由 smilingkiss 于 2013-9-30 09:37 编辑

Henry老师,想请教一下,我的窗体设置了:
Me.AllowEdits = Me.NewRecord,
如果不是新增记录,只是修改,那么文本框需要双击才能编辑,实现方法如下:
设置一个复选框check32,然后在窗体成为当前的事件上:
Private Sub Form_Current()
  Me.AllowEdits = Me.NewRecord
  Me.Check32 = False
  
  If Me.NewRecord Then
    Me.Check32 = True
  End If
End Sub

然后在文本框的控件上通过双击调用如下函数:
Private Sub DoubleClick_for_Edit()
  If Not Me.NewRecord Then
    Me.AllowEdits = True
  End If
End Sub

编辑完毕退出文本框,则有一下函数确保重新锁定:Private Sub Combo10_Exit(Cancel As Integer)
   If Me.Check32 = False Then
     Call Exit_for_Edit
   End If
End Sub


Private Sub Exit_for_Edit()
  If (Not Me.NewRecord) And Me.AllowEdits = True Then
    Me.AllowEdits = Me.NewRecord
    Me.Refresh
  End If
End Sub

以上功能一旦在窗体的“更新前”事件作出了“cancel=true”,则全部失效,
所以特意请教Henry老师是什么回事,如果确实有必要运行窗体的“更新前”事件,并且有“cancel=true”,应该如何恢复之前需要双击才能编辑的功能呢?谢谢!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-14 11:03 , Processed in 0.082225 second(s), 30 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

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