ASP.NET MVC 和代码隐藏文件

  • Hartmut Wilms
  • 张善友

2008 年 10 月 3 日

话题:.NET语言 & 开发

ASP.NET MVC 社区讨论了在使用 WebFormsViewEngine 时,是否仍然需要代码隐藏文件,以及这是一个优点还是缺点或甚至是一个问题。

ASP.NET MVC 默认仍然使用 WebFormsViewEngine。当使用 Visual Studio 向 ASP.NET MVC 应用程序增加一个 WebForms 视图时会自动增加一个代码隐藏文件和一个设计器文件。许多人认为代码隐藏文件已经被废弃了,它们的用法颇令人困惑,因为开发人员倾向于使用像传统的合而为一的 ASP.NET Web 窗体那样的视图。

代码隐藏文件是一个诱惑。对于不熟悉 ASP.NET MVC (ASP.NET MVC 还不到一年时间而且还没有发布)但是有 Web 窗体开发背景(大多数)的开发人员,他们始终有一个将代码写入隐藏代码文件倾向。这会使得在视图里的逻辑难以测试,最坏的可能是甚至在代码隐藏文件中包含的逻辑直接调用数据库或者是 web service,以致完全绕过模型同视图的分离。

Steve 解释了在某种情况下代码隐藏文件是一个不好但却必不可少的东西,例如你想在一个强类型的视图通过强类型方式引用模型(Model)。有写人认为隐藏代码页也可用来存储一些视图逻辑,而其他方式可能会弄乱 ASPX 文件。最后但并不是最不重要的一点是他们为了在 ASPX 文件上获得智能提示技术的支持。至于第一个问题,

Tim Barcz

演示了如何使用

没有代码隐藏使用强类型的 ViewData

,通过合并泛型的 CLR 表示法来取代 C# 或者 VB 的表示法:

Inherits="System.Web.Mvc.ViewPage`1[[ABCCompany.MVC.Web.Models.LoginData, ABCCompany.MVC.Web]]"

CLR 表示法在单引号后面指定了泛型参数的数量,后面跟参数和包含参数类型的程序集。

 

Luis Abreu

不同意 Steve 的用法并在

贴子

做出了回应。他说“不能确定删除隐藏代码文件就可以弥补一个‘不合格’程序员的不足”,因为逻辑仍然可以放在 ASPX 文件的脚本块里。Luis 也不同意“哑”视图的一般观点。他认为视图可能混合了“展现的相关代码”,并且这些代码应该被放在隐藏代码文件中而不是在控制器中或者直接写在 ASPX 文件里,这样会破坏标记和代码之间的清晰分离。





查看英文原文:
ASP.NET MVC and Codebehind Files
.NET语言 & 开发