访问子表单可见性

Posted

技术标签:

【中文标题】访问子表单可见性【英文标题】:Access Subform Visibility 【发布时间】:2012-12-24 14:14:30 【问题描述】:

我有一个访问表单,其中包含从表格填充的表单名称的下拉列表。当有人从下拉列表中选择特定项目时,我希望能够显示相应的子表单中的 1 个。例如,我在下拉列表中有表格 1、表格 2、表格 3。我选择表格 2,然后出现子表格 2。我尝试访问 VBA 中的子窗体可见属性,但遇到了多个错误,它从来没有完全奏效。有人可以帮忙吗?

这是填充下拉列表的代码:

Private Sub Form_Load()

Dim dba As Database
Dim rst As Recordset
Dim SQL As String

Set dba = CurrentDb
Set rst = dba.OpenRecordset("tbl_Forms", dbOpenDynaset, dbSeeChanges)
SQL = "SELECT ListName FROM tbl_Forms"
Set rst = dba.OpenRecordset(SQL, dbOpenDynaset, dbSeeChanges)

Set rst = Nothing
Set dba = Nothing
End Sub

对于我尝试的子表单可见性:

forms!mainform.Form1.visbile = false 
forms!mainform.Form2.visbile = false
forms!mainform.Form3.visbile = false

Select case dropdown
case 1 
forms!mainform.Form1.visbile = true 
forms!mainform.Form2.visbile = false
forms!mainform.Form3.visbile = false
case 2
forms!mainform.Form1.visbile = false
forms!mainform.Form2.visbile = true
forms!mainform.Form3.visbile = false
case 3 
forms!mainform.Form1.visbile = false
forms!mainform.Form2.visbile = false
forms!mainform.Form3.visbile = true
end select 

【问题讨论】:

请发布您尝试过的代码?我们可以通过这种方式提供更多帮助。否则,我们所能做的就是问您更多问题...... 【参考方案1】:

这是粗略的,但它应该给你一个开始。您可以使用所需子表单的字符串名称设置子表单容器的源对象。完成此操作后,您可以获取对 MS Access 定义的基本表单类的引用,并使用其中定义的属性和方法。

您也可以根据需要获取对特定表单的引用,但这会变得更加复杂。

从这里开始,您需要稍微玩一下它,让它按照您想要的方式运行。

Option Compare Database
Option Explicit

Private currentSubformReference As Form


Private Sub cboSubForms_AfterUpdate()
    LoadSubform (cboSubForms)
    currentSubformReference.DividingLines = False
    currentSubformReference.ControlBox = False
    '  . . . Etc
End Sub


Private Sub LoadSubform(ByVal SubformName As String)

    'Set the SourceObject property of the subform/subreport
    ' container object on your form:
    Me.sfmContainer.SourceObject = SubformName

    ' Grab a reference to the Form that is used as the
    ' SourceObject (this will only get you access to the
    ' properties exposed by the MS Access Form Class):
    Set currentSubformReference = Me.sfmContainer.Form

End Sub

【讨论】:

【参考方案2】:

在 Dropdown 中将三个值写为 Form1、Form2、Form3(或任何您的表单名称),然后编写代码:

forms!mainform.Form1.visbile = false 
forms!mainform.Form2.visbile = false
forms!mainform.Form3.visbile = false

With Me.    

Select case Me.DropDownName.Value
case "Form1" 
 With Me.MainFormName.Form
 .Form1.visbile = true 
 .Form2.visbile = false
 .Form3.visbile = false
 End With 
case "Form2" 
 With Me.MainFormName.Form
 .Form1.visbile = false 
 .Form2.visbile = true
 .Form3.visbile = false
 End With
  case "Form3" 
 With Me.MainFormName.Form
 .Form1.visbile = false 
 .Form2.visbile = false
 .Form3.visbile = true
 End With
  End Select  
  End With 

【讨论】:

以上是关于访问子表单可见性的主要内容,如果未能解决你的问题,请参考以下文章

图片框可见性中的动画gif随委托子和后台线程而变化

iOS10 UI教程视图和子视图的可见性

ExtJs 确定表单加载的可见性

根据组合框选择切换表单上其他字段的可见性 - MS Access

VUE 切换子组件元素可见性

子报表可见性