设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

[模块/函数] 【新手入门】之七:嵌套与并列——再谈If流程问题

[复制链接]
1#
发表于 2013-3-18 11:44:57 | 显示全部楼层
本帖最后由 ycxchen 于 2013-3-18 18:01 编辑

有劳版主!我觉得, DoCmd.GoToRecord , , acNewRec语句在end if语句后面的,但程序判断到出生日期为空这部分就不会判断第3层和之后的语句,为何直接跳转到GotoRecord,这是为什么呢?
2#
发表于 2013-3-19 09:20:54 | 显示全部楼层
本帖最后由 ycxchen 于 2013-3-19 09:33 编辑
roych 发表于 2013-3-18 19:32
If语句是这样执行的:
If 条件成立 Then
  执行语句1


版主,我的理解的与你的一样,对有一定VBA基础的人来说,这是很容易理解的。但是,你试过没有,条件不成立也会执行里面的嵌套语句,例如,当出生日期为空,出现提示,按确定后,程序并不是再进入判断参加工作日期是否为空值的语句,而是直接 运行到DoCmd.GoToRecord , , acNewRec语句,就是说程序不执行If部分已经到GotoRecord了,为什么呢?
3#
发表于 2013-3-19 12:06:18 | 显示全部楼层
是不是与msgbox函数“确定”按钮获得焦点事件有关?
4#
发表于 2013-3-20 11:08:31 | 显示全部楼层
本帖最后由 ycxchen 于 2013-3-20 11:12 编辑

     加入了“出生日期.SetFocus”语句,情况一样,什么原因呢?

本帖子中包含更多资源

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

x
5#
发表于 2013-3-21 08:55:18 | 显示全部楼层
衷心感谢roych版主的悉心指教!明白!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-10 03:36 , Processed in 0.089956 second(s), 29 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

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