【Access小品】是非难辨--子窗体打开概述-煮江品茶
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> Access数据库-教程


【Access小品】是非难辨--子窗体打开概述

发表时间:2015/7/23 13:29:31 评论(0) 浏览(8415)  评论 | 加入收藏 | 复制
   
摘 要:【Access小品】是非难辨--子窗体打开概述
正 文:
  有版友打开了一个主子窗体,于是乎用“Forms!子窗体名称!控件名称”来读写数据,结果跳错。这个情况涉及到窗体打开的概念,便决定说道说道。窗体是否处于打开状态原本是一个直观而简单的问题,看得见窗体界面了,窗体就应该说是打开了。这个看似再简单不过的问题,其实远比想象中要复杂。复杂的原因在于Access中存在双重标准,标准不同是否打开的结论相异,处理的方法和手段也就大相径庭。

  在Access中有两个集合与窗体有关,其一是AllFroms集合对象,该集合的元素由所有窗体组成,与其是否打开的状态无关。另外一个就是Forms集合对象,这个集合是所有用Docmd.OpenForm命令打开的窗体对象所组成。由此,这里就出现了第一个关于窗体是否打开的判断标准,也就是存在于Forms中的窗体为已打开窗体。便也就可以从Forms("窗体名称")或Forms!窗体名称出发,找到窗体上的控件,并对控件的某些属性进行操作。

  天下本无事,问题却出在主子窗体的打开上。Docmd.OpenForm命令打开主窗体时,它只将主窗体Add到Forms集合中,而没有理会子窗体,于是我们在Forms中看不到子窗体这个窗体元素。那么子窗体到底打开了没有呢?当然是打开了!不打开你怎么看得见窗体所呈现的内容。你可能说这不对,Forms中没有怎么能算打开呢?不能说你不对,因为你用的判断标准确实存在。可是你是否想到,可能还存在另外的一个判断标准?这个标准就是看窗体的打开事件是否执行了。如果打开事件执行了,窗体就已经被打开了。你可以试试,子窗体的打开事件这个时候是被执行了的,所以我们也可以说子窗体被打开了。

  实际上,无论窗体是否存在于Forms中,只要它呈现在你的眼前,便一定会触发窗体打开事件。所以,用窗体的打开事件是否被触发,来作为窗体是否打开的判断标准更具有普适性(即存在于Forms中是窗体打开状态的特例)。不过这个普适性并不能指导你来针对不同情况处理窗体上的控件。能指导你分别情况处理问题的判断标准,还只能依据窗体是否存在于Forms中。也就是说Forms中存在的窗体,可以用Forms("窗体名称")查找其控件,并进行处理;Forms中不存在的窗体,但它作为子窗体已经打开了,则只能通过主窗体中的子窗体控件来逐级找到子窗体中的控件,并进行处理。

  你可能觉得论述得太搅合了,看不明白说的是什么。其实论述复杂只是为了炫耀一番,与实际处理问题没什么太大关系。由此,你便不至于被唬住。你只需要记住主子窗体中不要用Forms("窗体名称")或Forms!窗体名称这样的写法去找子窗体控件就行了。至于这种情况下怎么去找,是个简单问题,在此不赘述。


示例:点击下载此附件


视图:



Access软件网交流QQ群(群号:198465573)
 
 相关文章
【Access小品】亚投行--事件概述  【煮江品茶  2015/3/30】
【Access小品】搞球不清--Null的概述  【煮江品茶  2015/5/28】
用代码打开Access2010或Access2013版中链接表管理...  【麥田  2015/6/6】
ACCESS分享--关闭所有打开着的窗体  【杜超  2015/6/15】
快速开发平台--“打开窗体是不加载数据”不起作用  【宏鹏  2015/7/1】
子窗体计算控件数值保存时为空值的解决办法  【王三平  2015/7/18】
【Access小品】抽丝剥茧--算法及算法实现概述  【煮江品茶  2015/7/21】
常见问答
技术分类
相关资源
文章搜索
关于作者

煮江品茶

文章分类

文章存档

友情链接