Access父子窗体引用的详细教程
- 2017-07-20 20:57:00
- zstmtony 原创
- 17963
Access父子窗体相互引用的语法解释
Access初学者除了对字符串连接容易困惑之外,另一个比较容易晕菜的问题,就是父子窗体对象或控件的引用
Access入门者常常弄不清子窗体控件与子窗体之间的区别,所以常常在主窗体,不知道如何引用Access子窗体里的对象
或在Access子窗体中,不知道如何引用父窗体里的对象
首先,我们先要明白,子窗体控件 是一个容器,它里面包含着一个 另一个窗体(通过在源对象属性 来设置 里面包含着哪个窗体)
假如主窗体为 frm订单,它里面有一个子窗体控件, 这个子窗体控件名称叫做 sfmSubform, 它的源对象属性 设置为 frm订单明细, frm订单明细这个窗体里 有一个 数量 控件
如果我们在主窗体里 想引用 子窗体控件,可以使用 me.sfmSubform ,这个就指向子窗体控件
但我们要明白 数量 控件 并不是放在子窗体控件里,而是在 frm订单明细 这个窗体里
那们要引用 “数量”这个控件,应该如何引用呢?
正确的方法是先找到 这个frm订单明细 这个窗体,如果直接用 frm订单明细.数量 是不行的,因为 frm订单明细这个窗体 这是单独打开的。它是放在 主窗体 frm订单里面
所以要这样引用 ,先找开 这个窗体:me.sfmSubform.form 这样就对应到 这个子窗体控件 里面的窗体 了(也是frm订单明细这个子窗体)了
然后,再加上控件名: me.sfmSubform.form. 数量
如果在 子窗体 里 数量 控件的相关事件里 如果引用父窗体呢(如父窗体里有一个订单号)
则需要这样引用: me.parent.订单号 或me.parent.form.订单号 都可以
更多有关父子窗体的语法解释,可参考下面的详细教程
例子:
Mainform 是 主窗体
Subform1 是主窗体里面的子窗体的名称
Subform2 是Subform1子窗体里面的子窗体
正 文:
父子窗体的语法介绍 From Keri Hardwick
例子:
Mainform 是 主窗体
Subform1 是主窗体里面的子窗体的名称
Subform2 是Subform1子窗体里面的子窗体
|
|
|
|
如果你在主窗体 |
如果你在子窗体1 |
要参照一个窗体属性,例如:RecordSource |
|
|
在主窗体 |
Me.RecordSource |
Me.Parent.RecordSource |
在子窗体1 |
Me!Subform1.Form.RecordSource |
Me.RecordSource |
在子窗体2 |
Me!Subform1.Form!Subform2.Form. RecordSource |
Me!Subform2.Form.RecordSource |
在照控件 |
|
|
在主窗体 |
Me!ControlName |
Me.Parent!ControlName |
在子窗体1 |
Me!Subform1.Form!ControlName |
Me!ControlName |
在子窗体2 |
Me!Subform1.Form!Subform2.Form! ControlName |
Me!Subform2.Form!ControlName |
要参照一个控件属性,例如: Enabled |
|
|
在主窗体 |
Me!ControlName.Enabled |
Me.Parent!ControlName.Enabled |
在子窗体1 |
Me!Subform1.Form!ControlName.Enabled |
Me!ControlName.Enabled |
在子窗体2 |
Me!Subform1.Form!Subform2.Form! ControlName.Enabled |
Me!Subform2.Form!ControlName.Enabled |
要参照一个子窗体控件属性, 例如SourceObject |
|
|
在主窗体 |
N/A |
N/A |
在子窗体1 |
Me!Subform1.SourceObject |
N/A |
在子窗体2 |
Me!Subform1.Form!Subform2.SourceObject |
Me!Subform2.SourceObject |
|
|
|
|
|
|
|
如果你在子窗体2 |
不在窗体里 |
要参照一个窗体属性,例如:RecordSource |
|
|
在主窗体 |
Me.Parent.Parent.RecordSource |
Forms!Mainform.RecordSource |
在子窗体1 |
Me.Parent.RecordSource |
Forms!Mainform!Subform1.Form.RecordSource |
在子窗体2 |
Me.RecordSource |
Forms!Mainform!Subform1.Form!Subform2. Form.RecordSource |
要参照一个控件 |
|
|
在主窗体 |
Me.Parent.Parent!ControlName |
Forms!Mainform!ControlName |
在子窗体1 |
Me.Parent!ControlName |
Forms!Mainform!Subform1.Form!ControlName |
在子窗体2 |
Me!ControlName |
Forms!Mainform!Subform1.Form!Subform2. Form!ControlName |
要参照一个控件属性,例如: Enabled |
|
|
在主窗体 |
Me.Parent.Parent!ControlName.Enabled |
Forms!Mainform!ControlName.Enabled |
在子窗体1 |
Me.Parent!ControlName.Enabled |
Forms!Mainform!Subform1.Form!ControlName.Enabled |
在子窗体2 |
Me!ControlName.Enabled |
Forms!Mainform!Subform1.Form!Subform2. Form!ControlName.Enabled |
要参照一个子窗体控件属性:SourceObject |
|
|
在主窗体 |
N/A |
N/A |
在子窗体1 |
N/A |
Forms!Mainform!Subform1.SourceObject |
在子窗体2 |
N/A |
Forms!Mainform!Subform1.Form!Subform2. SourceObject |
摘自Office交流网 最早期的网站 轻魂源码(www.zstmcomputer.com)
- office课程播放地址及课程明细
- Excel Word PPT Access VBA等Office技巧学习平台
- 将( .accdb) 文件格式数据库转换为早期版本(.mdb)的文件格式
- 将早期的数据库文件格式(.mdb)转换为 (.accdb) 文件格式
- KB5002984:配置 Jet Red Database Engine 数据库引擎和访问连接引擎以阻止对远程数据库的访问(remote table)
- Access 365 /Access 2019 数据库中哪些函数功能和属性被沙箱模式阻止(如未启动宏时)
- Access Runtime(运行时)最全的下载(2007 2010 2013 2016 2019 Access 365)
- Activex控件或Dll 在某些电脑无法正常注册的解决办法(regsvr32注册时卡住)
- office使用部分控件时提示“您没有使用该ActiveX控件许可的问题”的解决方法
- RTF文件(富文本格式)的一些解析
- Access树控件(treeview) 64位Office下出现横向滚动条不会自动定位的解决办法
- Access中国树控件 在win10电脑 节点行间距太小的解决办法
- EXCEL 2019 64位版(Office 2019 64位)早就支持64位Treeview 树控件 ListView列表等64位MSCOMMCTL.OCX控件下载
- VBA或VB6调用WebService(直接Post方式)并解析返回的XML
- 早期PB程序连接Sqlserver出现错误
- MMC 不能打开文件C:/Program Files/Microsoft SQL Server/80/Tools/Binn/SQL Server Enterprise Manager.MSC 可能是由于文件不存在,不是一个MMC控制台,或者用后来的MMC版
- sql server连接不了的解决办法
- localhost与127.0.0.1区别
- Roych的浅谈数据库开发系列(Sql Server)
- sqlserver 自动备份对备份目录没有存取权限的解决办法
- 安装Sql server 2005 express 和SQLServer2005 Express版企业管理器 SQLServer2005_SSMSEE
联系人: | 王先生 |
---|---|
Email: | 18449932@qq.com |
QQ: | 18449932 |
微博: | officecn01 |