以文本方式查看主题 - Foxtable(狐表) (http://foxtable.net/bbs/index.asp) -- 专家坐堂 (http://foxtable.net/bbs/list.asp?boardid=2) ---- filter如何筛选其他窗口控件的值 (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=79145) |
||||
-- 作者:szsmall -- 发布时间:2015/12/25 1:04:00 -- filter如何筛选其他窗口控件的值 从订购表录入打开计划单选择时,计划单选择表能按控件上的项目名称,显示相应的计划单嘛? |
||||
-- 作者:Hyphen -- 发布时间:2015/12/25 8:15:00 -- If Forms("订购单录入").Opened Then |
||||
-- 作者:szsmall -- 发布时间:2015/12/26 1:23:00 -- 问题已经解决,把下面的代码放到订购单选择afterload里面就行了 Tables("DG计划单选择_计划单总").Filter = "工程名称 = \'"& Forms("订购单_录入").controls("ComboBox2").text &"\'" 现在想问一下,如何按“全部”按钮,能把相应项目的计划单明细显示出来?明细表和总表通过订单号关联,明细表没有项目名称,无法直接filter项目名称。 另外,如果想增加一个搜索按钮,搜索对应项目计划单里的某项材料情况,又该怎么处理。
[此贴子已经被作者于2015/12/26 1:26:23编辑过]
|
||||
-- 作者:Hyphen -- 发布时间:2015/12/26 9:59:00 --
|
||||
-- 作者:szsmall -- 发布时间:2015/12/31 0:41:00 -- “显示全部” Dim t1 As WinForm.Table = e.Form.Controls("计划单总") Dim ids As List(Of String) = t1.Table.DataTable.GetValues("计划单号",t1.Table.Filter) Dim t2 As WinForm.Table = e.Form.Controls("计划单明细") t2.Table.Filter = "计划单号 in (\'" & String.Join("\',\'",ids.ToArray()) & "\')" Dim g As WinForm.CheckBox = e.Form.Controls("CheckBox1") g.Checked = False “搜索” Dim t1 As WinForm.Table = e.Form.Controls("计划单总") Dim ids As List(Of String) = t1.Table.DataTable.GetValues("计划单号",t1.Table.Filter) Dim t2 As WinForm.Table = e.Form.Controls("计划单明细") Dim filter As String = "计划单号 in (\'" & String.Join("\',\'",ids.ToArray()) & "\') " Dim txt As WinForm.TextBox = e.Form.Controls("TextBox1") If txt.Text > "" Then filter = filter & " and 材料名称 like \'%" & txt.Text & "%\' " End If -------------------------------------- 想问一下“t1.Table.DataTable.GetValues”.为什么要加Table.DataTable?试着去掉,显示“不是WinForm.Table的成员“。 [此贴子已经被作者于2015/12/31 0:41:56编辑过]
|
||||
-- 作者:Hyphen -- 发布时间:2015/12/31 8:41:00 -- t1是控件,t1.Table是控件里的表格,GetValues是DataTable的方法 |