Foxtable(狐表)用户栏目专家坐堂 → MainTableChanged 事件中关闭窗口代码无效原因?


  共有11662人关注过本帖树形打印复制链接

主题:MainTableChanged 事件中关闭窗口代码无效原因?

帅哥哟,离线,有人找我吗?
shixia
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:754 积分:6991 威望:0 精华:1 注册:2008/9/2 20:04:00
MainTableChanged 事件中关闭窗口代码无效原因?  发帖心情 Post By:2010/8/28 11:35:00 [只看该作者]

下面这段代码在MainTableChanged项目事件中,应该是可以执行的,但是如果表一旦多了,有A、B、C、…表时,用下面这段代码无效: 

if MainTable.name <> "表A" Then

    Forms("表A").Close() '关闭表A对应的独立窗口

elseif MainTable.name <> "表B" Then

    Forms("表B").Close() '关闭表B对应的独立窗口

then

没有办法,只好在菜单中切换主表时加下面这段代码:

For Each frm As WinForm.Form In Forms
      frm.Close
Next

请狐爸看看,MainTableChanged中的代码为何不能执行,是不是项目中其它地方的代码影响这段代码的执行。


 回到顶部
帅哥哟,离线,有人找我吗?
blackzhu
  2楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 一级勋章
等级:狐仙 帖子:9875 积分:57584 威望:0 精华:15 注册:2008/9/1 9:45:00
  发帖心情 Post By:2010/8/28 11:57:00 [只看该作者]

if MainTable.name <> "表A" Then

    Forms("表A").Close() '关闭表A对应的独立窗口

elseif MainTable.name <> "表B" Then

    Forms("表B").Close() '关闭表B对应的独立窗口

then

 

 

 这个是你直接贴上来还是再写的.

 

最后结束语怎么是then呢,不是end if 吗?


 回到顶部
帅哥哟,离线,有人找我吗?
czy
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33945 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2010/8/28 18:25:00 [只看该作者]

一楼应该逻辑问题。

 

不如直接这样?

 

For Each frm As WinForm.Form In Forms
    If frm.TableName <> MainTable.name
        frm.Close
    End If
Next


 回到顶部
帅哥哟,离线,有人找我吗?
czy
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33945 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2010/8/28 19:25:00 [只看该作者]

从一楼的注释来看,似乎这样更合理。

 

For Each Frm As WinForm.Form In Forms '返回所有窗口
    If Frm.TableName <> MainTable.Name '如果窗口所在表不等于本表
        If Frm.FormStyle = 2 Then '如果窗口类型等于独立
            Frm.Close
        End If
    End If
Next

[此贴子已经被作者于2010-8-28 23:34:58编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
shixia
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:754 积分:6991 威望:0 精华:1 注册:2008/9/2 20:04:00
  发帖心情 Post By:2010/8/28 20:51:00 [只看该作者]

then 应该为end if ,这是我写的时候笔误,在狐表中是正确的写法,否则保存不了啊。

在帮助中有一 段帮助:

自动关闭与隐藏

本课的内容仅针对独立型窗口,因为其它类型的窗口并不存在自动隐藏的问题。
我们已经知道,独立窗口是可以共享的,独立窗口一旦打开,切换到其他主表后,窗口仍然是可见的。
有的时候我们并不希望这样,例如有一个设计好的窗口,名为“订单筛选”,我们希望进入订单表的时候,该窗口能够自动打开,而离开订单表的时候,能够自动关闭。
实现这个要求的代码很简单,只需将项目的MainTableChanged事件设为:

If MainTable.Name = "订单" Then
    Forms(
"订单筛选").Show()
Else

    Forms(
"订单筛选").Close()
End
If

 

在实际中,一个主表有多个窗口,在不同的主表之间进行切换时,都希望关闭前一主表的所有窗口,主表一多就用上了elseif 来判断,所以用<>号比=号方便,只要不是表A就关闭表A中所有窗口,从理论上讲用<>号没有错,但为什么就不执行呢?

CZY代码有理,但是如果表A有多个窗口,那么这些窗口名称不可能都等于表名,因此这段代码也不好用。谢谢CZY。


 回到顶部
帅哥哟,离线,有人找我吗?
czy
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33945 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2010/8/28 20:57:00 [只看该作者]

以下是引用shixia在2010-8-28 20:51:00的发言:

 

在实际中,一个主表有多个窗口,在不同的主表之间进行切换时,都希望关闭前一主表的所有窗口,主表一多就用上了elseif 来判断,所以用<>号比=号方便,只要不是表A就关闭表A中所有窗口,从理论上讲用<>号没有错,但为什么就不执行呢?

CZY代码有理,但是如果表A有多个窗口,那么这些窗口名称不可能都等于表名,因此这段代码也不好用。谢谢CZY。

 

可能你理解有误,我的代码中没有判断窗口名称,我只是判断不是指定表中的所有窗口,和不是指定表中所有的独立窗口,如果符合这两个条件就关闭窗口,否则不操作。

[此贴子已经被作者于2010-8-28 20:58:31编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
czy
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33945 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2010/8/28 21:03:00 [只看该作者]

呵呵,我楼上可能理解错楼主的意思了。

 回到顶部
帅哥哟,离线,有人找我吗?
shixia
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:754 积分:6991 威望:0 精华:1 注册:2008/9/2 20:04:00
  发帖心情 Post By:2010/8/28 22:06:00 [只看该作者]

哦,是我没看清楚代码的意思,C版代码有效,不好意思了。另FormStyle在帮助中找不到,那可能是窗口类型的意思,看来版主有私货啊。谢谢

 回到顶部
帅哥哟,离线,有人找我吗?
czy
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 一级勋章 三级勋章 二级勋章
等级:超级版主 帖子:6318 积分:33945 威望:0 精华:10 注册:2008/8/31 20:56:00
  发帖心情 Post By:2010/8/28 22:13:00 [只看该作者]

以下是引用shixia在2010-8-28 22:06:00的发言:
哦,是我没看清楚代码的意思,C版代码有效,不好意思了。另FormStyle在帮助中找不到,那可能是窗口类型的意思,看来版主有私货啊。谢谢

 

一样一样的,版主没有一点私货,这是我自己摸索出来的。


 回到顶部