Rss & SiteMap
Foxtable(狐表) http://www.foxtable.com
如是当天,没必要设全局变量,可以直接 用#" & Date.Today & "#"
Dim dst As WinForm.DataList = e.Form.Controls("DataList1")
dst.Rowfilter="[班次]='甲白' and [生产日期] =#" & Date.Today & "#"
请你说明是放在哪个事件中的及你的正确的代码发上来,以便大家学习
怎样设置全局变量,在哪设哦。
Initialize
数据已经加载,所有的DataTable都已经生成,即将生成Table和窗口的时候执行,通常在此添加全局变量,以及针对DataTable的初始化设置。
例如将Initialize事件代码设为:
Vars.Add("Aggregate",GetType(Boolean),False)
DataTables("订单").DataCols("日期").DefaultValue = Date.Today()
上面的代码增加了一个逻辑型全局变量Aggregate,并将订单表日期列的默认值设置当天日期。
怎样设置全局变量,在哪设哦。
全局变量
在Foxtable中实际开发的时候,你会发现,你所编写的代码分布在各个事件中。
我们之前提到的变量,都只能在定义该变量的事件代码中使用,我们无法用它们在不同的事件代码中传递信息。
全局变量就是为解决这个问题而提出的,所谓全局变量,就是在任何一个事件代码中都可以使用的变量。
全局变量存储在集合Vars中。
全局变量的具体使用方法,我们会在今后的章节介绍,现在你只需了解这个概念。
增加全局变量
语法
Vars.Add(VarName,GetType(Type))
Vars.Add(VarName,GetType(Type),Value)
参数
VarName: 全局变量名称
Type: 全局变量类型,需要配合GetType关键字来获得数据类型,例如GetType(String)表示字符型,GetType(Boolean)表示逻辑型。
Value: 可选参数,用于设置全局变量的初始值。
例如:
Vars.Add(
"Mark1",GetType(Boolean),False)表示增加一个逻辑型全局变量Mark1,初始值为False
Vars.Add(
"起始日期",GetType(Date),#12/31/2007#)表示增加一个日期型全局变量,名称为“起始日期”,初始值为#12/31/2007#
引用全局变量
增加全局变量后,你既可在任何事件代码中引用全局变量。
引用全局变量的语法为:
Vars(VarName)
VarName:全局变量名称。
例如:
If
Vars("Mark1") = False Then使用全局变量
为了能够在不同的事件代码中交流数据,需要使用全局变量。
下面我们用一个简单的例子,来说明如何使用全局变量。
假定我们规定表A每天只能增加500行,为实现此目的,需要进行如下设置:
1、在项目事件Initialize中加入代码:
Vars.Add("Count",GetType(Integer))
上面的代码,增加了一个名为Count的全局变量,该变量为整数型,用于记录已经增加的行数。
2、在表A的DataRowAdded事件中加入代码:
Vars("Count") = Vars("Count") + 1
这样每增加一行,全局变量Count就会增加1
3、然后在表A的DataRowDeleted事件中加入代码:
Vars(
"Count") = Vars("Count") - 1这样每删除一行,全局变量Count就会减1
4、最后在表A的BeforeAddDataRow事件中加入代码:
If
Vars("Count") >= 500 Then '如果已经增加了500行这个例子并没有多少实际的意义,重新打开项目,我们又可以增加500行了,不过这个例子很好地说明了如何使用全局变量在不同的事件中交流数据。
如果要跟踪全局变量值的变化,可以使用事件:GlobalVariableChanged