【access小品】黑箱---程序开发的一种机巧思路
时 间:2010-07-12 00:00:00
作 者:todaynew ID:10802 城市:武汉
摘 要:黑箱
正 文:
昨日,版友子煜同志上传了一个关于追加查询问题的实例,读出数据和写入数据的两个表字段多,字段名复杂,加之还存在一些逻辑上的矛盾。因此直接写追加查询很是麻烦,用ADO数据集解决也很罗嗦。于是乎,需要另辟蹊径,超常规解决问题。通过观察发现,所需追加的来源和被追加的目标在窗体上反映的是很清晰的,这就提供了一个解决问题的基本思路,叫做“从窗体中来到窗体中去”,窗体背后是些什么玩意完全可以不必考虑。这也就是一种被称之为黑箱管理的思维方法。实际上Access设计中,常常需要这样去建立解决问题的思路,这个思路可以导致许多通用程序的构建。
Private Sub Command4_Click()
Dim frm1 As Form
Dim ctls1 As Controls
Dim ctl1 As Control
Dim frm2 As Form
Dim ctls2 As Controls
Dim i As Long, j As Long
Set frm1 = Me.条件查询入库明细子窗体.Form
Set ctls1 = frm1.Controls
Set frm2 = Forms("出库主窗体").Controls("F_ProIn2").Form
Set ctls2 = frm2.Controls
For i = 1 To frm1.RecordsetClone.RecordCount
frm1.SelTop = i
If ctls1("P_Select") = True Then
Forms("出库主窗体").Form.SetFocus
Forms("出库主窗体").Controls("F_ProIn2").SetFocus
If Nz(ctls2("P_ID").Value, 0) <> 0 Then
DoCmd.RunCommand acCmdRecordsGoToNew
End If
For Each ctl1 In ctls1
If ctl1.ControlType <> acLabel Then
If ctlEx(frm2, ctl1.Name) = True Then
ctls2(ctl1.Name).Value = ctl1.Value
End If
End If
Next ctl1
End If
Next
frm1.Requery
frm2.Requery
End Sub
Function ctlEx(frm As Form, ctlname As String) As Boolean
Dim ctls As Controls
Dim ctl As Control
Set ctls = frm.Controls
ctlEx = False
For Each ctl In ctls
If ctl.Name = ctlname Then
ctlEx = True
Exit For
End If
Next ctl
End Function
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 统计当月之前(不含当月)的记录...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)
- 【Access高效办公】上月累...(01.06)
- 【Access Inputbo...(12.23)
- 【Access Dsum示例】...(12.16)

学习心得
最新文章
- 仓库管理实战课程(9)-开发往来单...(04.02)
- 仓库管理实战课程(8)-商品信息功...(04.01)
- 仓库管理实战课程(7)-链接表(03.31)
- 仓库管理实战课程(6)-创建查询(03.29)
- 仓库管理实战课程(5)-字段属性(03.27)
- 设备装配出入库管理系统;基于Acc...(03.24)
- 仓库管理实战课程(4)-建表操作(03.22)
- 仓库管理实战课程(3)-需求设计说...(03.19)
- 仓库管理实战课程(2)-软件背景和...(03.18)
- 仓库管理实战课程(1)-讲师介绍(03.16)