问题:窗体在运行时显示,在解决方案管理器中不显示

小引:

    虽然我知道实现《机房收费管理系统》会遇见各种问题,但是碰到这么狗血的问题,我真是大姑娘上花轿——头一回!

果:

   某天,具体时间忘了,只记得上了节课回来,就发现我刚做好的《机房收费系统》的frmMain窗体在解决方案资源管理器中找不到了,但是运行的时候却能正常的显示出来,当下我就郁闷了。本来一天的专业课,好不容易挤出时间,把界面显示做出来了,菜单栏也用英文名命名了,现在可好,啥也看不见了,难道要重来吗!呜呜呜。。。

因:

   因为我的洁癖,见不得“没用的”代码,将窗体中的一句话删了,直接造成了上面的结果,真是后患无穷啊!我到底是删了什么东西,这么神奇?

答案:


Public Class frmMain
End Class 


回想我的解决方法是:

第一,确定是因为自己的哪步修改引起的?

   记忆中,我是在修改了frmMain窗体的IsMdiContainer属性为true后,保存了就去上课了。下课回来再打开程序时就看不见了,所以,我又新建了一个窗体,将它的IsMdiContainer属性设置为true,我想,一山不容二虎,肯定会报错吧,结果发现自己对VS还是不够理解,在同一个解决方案中可以同时存在两个父窗体。所以,没报错。。。此时我已半疯,心里滴血~半天的功夫可能要没了,要重新做了。。。不行,再试试——

第二,对比窗体内部代码,观察我的窗体和新生成的有什么不一样!

    当然,从外观上看,我的frmMain窗体现在只剩下一个光杆类库了,如图:

问题:窗体在运行时显示,在解决方案管理器中不显示_第1张图片




   打开新建的窗体,发现在frm类中有这样一句话:

Public Class frm
End Class
   而我的类frmMain中没有,难道真的是因为这句话?算啦,死虎当活虎医,抱着试试看的态度,我把代码一改: 用到我的frmMain大老虎上,不到5秒的时间,药到病除,活力重现,frmMain老虎和其他的老虎一样一样的啦。

Public Class frmMain
End Class 

问题:窗体在运行时显示,在解决方案管理器中不显示_第2张图片

为什么我的“洁癖”会造成我的大老虎生病呢?

选中
Public Class frmMain
End Class 


按F1查找帮助,找到了最醒目的一段话:

问题:窗体在运行时显示,在解决方案管理器中不显示_第3张图片
   仔细一想,以前老师介绍过:我们使用的窗体其实就是封装好的类,我们使用的VS工具和VB工具在窗体上就是应用了面向对象的思想,直接将窗体为我们封装好,不用我们再用代码画一个个的“画”控件,在以前,要想做出程序,要先用代码“画”出窗体,才能真正开始写和程序运行有关的代码;
   但是,我将类frmMain.vb直接删掉,在显示上,窗体frmMain 就直接不存在了,只剩下一个类库,但是在我的在运行时却可以显示出来,而且能进行操作,在程序文件组成的UI部分,还能看见frmMain.Designer.vb,如图:

问题:窗体在运行时显示,在解决方案管理器中不显示_第4张图片

到底是谁控制窗体在运行时显示,又是谁让窗体在解决资源管理器中不显示了呢?

经过查资料终于知道了:


   FrmMain.vb 是指类代码。FrmMain.Designer.vb 是指界面设计代码。在 VB 2003 和之前的.net版本中这两部分是在一起的,从 VB 2005 以后才分开。也就是说,在之前的IDE里面,IDE将Designer.vb里面的代码全部放在窗体代码文件开头。

   简单的来说 .Designer.vb 保存的是用户界面设计自动生成的代码,里面写着的是比如 Form 的高度宽度啊、窗体上有个 TextBox 的 Text 啊之类这些东西,这些东西用户在 IDE 中只需要用鼠标去画并修改相应的控件属性就可以了,VS 会自动生成相应的代码保存到 Designer.vb 中。

在FrmMain.Designer.vb中,我们可以看见这样的描述:


问题:窗体在运行时显示,在解决方案管理器中不显示_第5张图片

相关解释:

   partial 信息只对编译器有用,编译器在编译时看到对某个类的描述是“碎”的(partial 的),它会去其他地方收集该类的其他碎片,然后把所有的该类的碎片组合成完整的一个类,再对其编译。-- @jizhongbo 简单地说就是我们可以把类写在不同的文件中,类名相同,用partial修饰后,IDE会找全类的碎片,然后粘在一块儿,形成完整的一个类。

我的理解:

   我们的frmMain.vb和frmMain.Designer.vb就是将一个类放在了不同的文件中,我将frmMain.vb删除后,“窗体类”在重组时不完整,便在右边的解决方案资源管理器中不显示了。但是因为一个“窗体类”负责显示的部分在FrmMain.Designer.vb,我删除的是frmMain.vb,所以没有影响窗体在运行时显示。

小结:

   尽管查资料和整理博客用的时间可以让我再重新建一个MDI窗体了,但是如果没有查资料的过程,就不会有现在的知识上的收获,有的更多的是对VS的胆怯和对自己当时的“傻”的懊悔。


了解更多frm.Designer.vb 的知识,向大家推荐:http://tieba.baidu.com/p/1822178540#


你可能感兴趣的:(错误总结)