InfoQ

新闻

ASP.NET MVC和代码隐藏文件

作者 Hartmut Wilms译者 张善友 发布于 2008年10月3日 下午8时16分

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

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

Steve Smith更进一步的表明ASP.NET MVC Codebehind文件的坏处,因为他们引诱开发人员将逻辑添加到视图上,视图在设计上应当保持“哑的”:
代码隐藏文件是一个诱惑。对于不熟悉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

2 条回复

回复

呵呵,ASP.NET不要使用MVC了 发表人 peng jiang 发表于 2008年10月9日 下午6时40分
说了半天等于没说 发表人 海上月 q 发表于 2008年10月17日 上午7时54分
  1. 返回顶部

    呵呵,ASP.NET不要使用MVC了

    2008年10月9日 下午6时40分 发表人 peng jiang

    从简化WEB应用的开发方面,ASP.NET作的不错了,为何MVC,想一想JSF怎样做的?

  2. 返回顶部

    说了半天等于没说

    2008年10月17日 上午7时54分 发表人 海上月 q

    同意Luis Abreu:“不能确定删除隐藏代码文件就可以弥补一个‘不合格’程序员的不足”,因为逻辑仍然可以放在ASPX文件的脚本块里.
    JSF的backing bean和这也没多大区别

深度内容

Flex与JSON及XML的互操作

平台需要互操作性。在这篇文章中,作者仔细研究了Flex和JSON及XML的互操作性。文章也包含了使用E4X库来将XML映射到图表和表格组件的内容,还演示了如何使用as3core库来解码JSON消息。

用Qi4j进行面向组合编程

本文将简要介绍面向组合编程(COP,Composite Oriented Programming)的概念,展示它如何规避OOP存在的一些问题,并重新点燃使用可重用部件组装领域模型(Domain Model)的希望。

系统开发——新学科,新教育

一门新的计算机学科——“系统开发”,强调人性化、匠艺、设计、创意、创新和新事物的涌现,并建议用被称为“bottega”的工作室替代乏善可陈的教室。

图书聚焦:Visual Studio 2008 揭秘

Mike Snell和Lars Powers用他们最近由Sams出版的新书《Visual Studio 2008揭秘》,试图帮助大家提高开发人员的生产力。本文包括一个下载样章——第10章调试。

BPEL为何不是BPM的圣杯?

Pierre Vigneras在本文中讨论了作为标准之一的BPEL所存在的问题。Pierre先给我们大致介绍了一个简单的并行流程,接着讨论了从业者在试图以一个结构化模型为基础表达非结构化流程时遇到的一系列问题。

基于范型的多语言编程

你是否仔细思考过,为什么人们总在讨论“要正确的语言做恰当的事情”?在这篇文章中,Sadek Drobi向你解释了为什么应该在系统内部混合使用多种语言。

采访与书摘《Pro Web 2.0 Application Development with GWT》

Jeff Dwyer就关于他的新书(《Pro Web 2.0 Application Development with GWT》)、GWT1.5以及创建可搜索的Ajax应用谈了一些他的见解。

时刻准备着,迎接IT业的春天

我们需要设身处地地为客户及客户的业务本身着想,与客户同舟共济。更多创新的思路、产品和模式也同样将为IT业带来新的出路。IT业并不需要坐以待毙,在春天到来之后,市场将会更加繁荣!