关于Mvc与WebForm的优缺点在网上的评论可谓不胜枚举,但脱离了我们的项目来谈这些意义就不大了。以我们这次改版来看,WebForm的优势有以下几点:

一,可以使用<#include>,css、html与js可以实现跨页面乃至夸项目的重用,Mvc没有发现此类功能;

二,可以精确的调用用户控件中的属性、字段、函数并可以获得相应的返回值,Mvc也未发现此类功能;

三,可以方便的将公共或保护性字段属性函数等应用到aspx页面上,Mvc无法直接调用控制其中的相应字段属性等。

针对以上WebForm的有点或Mvc的确点,我们在改版商铺写字楼时遵循了下面的几个规范予以弥补:

一,使用局部视图来实现html的重用;

二,对控制器中所用到的属性字段函数进行合理的封装,如将原有的变量集成到一个大的类中作为一个强类型视图传递的对象传给相应的视图,实现在视图中的方便使用。在这里对于类的划分需要尽可能的把相关性比较高的放到一块儿,优先采用类的组合而非继承,若需要放到视图对象中的字段是一个较大的复合类,如经纪人实体或房源实体,建议单独存放在ViewBag中。这些做法的目的比一方面希望这些变量使用起来更加方便,另一方面减小在视图中调用局部视图或函数的时候传递参数的颗粒度,也就提高了这些局部视图或函数的重用性,如用经纪人实体做参数的函数我们既可以在商铺写字楼中用,也可以用在普通的经纪人详情页中使用,而视图对象做参数无法实现这点;

三,将代码的重用单位放到对象和函数上,原则上不在控制器中创建不直接向浏览器做交代的函数,而是放在底层以方便重用。

在遵循了上述一些规范之后方才发现Mvc还是有些优点的:

一,优秀的Razor引擎使得在视图中使用C#代码更加方便流畅;

二,单个视图可以对应多个控制器,提高了代码的重用;

三,在主视图的ViewBag或ViewData中存储的对象可以在局部视图(仅限通过RenderPartial方式渲染的视图)或母版页中使用;

四,可以在视图中以函数方式重用普通的html代码到局部视图中且可以向局部视图中传递一个对象;

五,视图与控制器的分界更加清晰,局部视图的重用可以直接在视图中予以调用,而在WebForm中用户控件在后台代码中由于需要传参绑定而无法放在底层实现更高的重用。

除了上面的异同,还有一些在WebForm与Mvc中名字相同的对象,这些对象虽然名字相同,但是类型已经不是一个类型了,如:

         //
// 摘要:
// 为当前 HTTP 请求获取 System.Web.HttpRequestBase 对象。
//
// 返回结果:
// 请求对象。
public HttpRequestBase Request { get; }
//
// 摘要:
// 为当前 HTTP 响应获取 System.Web.HttpResponseBase 对象。
//
// 返回结果:
// 响应对象。
public HttpResponseBase Response { get; }

Mvc中的http对象

         //
// 摘要:
// 获取请求的页的 System.Web.HttpRequest 对象。
//
// 返回结果:
// 当前与该页关联的 System.Web.HttpRequest。
//
// 异常:
// System.Web.HttpException:
// System.Web.HttpRequest 对象不可用时发生。
[Browsable(false)]
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
public HttpRequest Request { get; }
//
// 摘要:
// 获取与该 System.Web.UI.Page 对象关联的 System.Web.HttpResponse 对象。该对象使您得以将 HTTP 响应数据发送到客户端,并包含有关该响应的信息。
//
// 返回结果:
// 当前与该页关联的 System.Web.HttpResponse。
//
// 异常:
// System.Web.HttpException:
// System.Web.HttpResponse 对象不可用。
[Browsable(false)]
[DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)]
public HttpResponse Response { get; }

WebForm中的http对象

由于类型不同,在Mvc中一些特性不再灵验,如在controller里面不能识别Response.End()页面会继续运行下面的代码,可以用return null来代替。另外也添加了一些好玩的属性函数如Request.IsAjaxRequest(),该函数可以用来判断是否异步访问。但毕竟相应对象的类型依然共用一个基类,它们的大多数属性函数用法依然相同。目前对相应对象的各种新的用法了解还是很有限,需要在今后的工作中加以总结,以最大化的发挥出框架的优势。

就现在的改版来说,我们做的尚不够好,但依然可以发现,在MVC中我们用的代码更少,重用的地方更多了。其实无论是MVC还是WebForm只要能够合理的使用都可以获得较高的效率及可维护性,要想提高代码的可维护性及性能还是需要我们定制并完善统一的标准,同时也要提高我们的个人水平。

Mvc与WebForm优缺点及Mvc的使用的更多相关文章

  1. MVC和WebForm区别

    WebForm的理解 1. WebForm概念 ASP.NETWebform提供了一个类似于Winform的事件响应GUI模型(event-drivenGUI),隐藏了HTTP.HTML.JavaSc ...

  2. asp.net MVC 和 webForm的区别

    asp.net MVC请求过程 ASP.NET MVC框架只是给开发者提供了开发web应用程序的一种选择,并不是要取代Webform这两种技术各有优缺点,开发者需要根据实际情况,选择对应的技术有时候, ...

  3. MVC与WebForm的区别

    在初步了解MVC后,发现很多人对于MVC和三层架构开发概念上会有很大的混淆,所以把这两天的学习笔记整理一下,分享给自己的同学们.同时也做一个小Demo,让没有接触过MVC开发的同学,能对MVC有一个简 ...

  4. MVC和WebForm 中国省市区三级联动

    MVC和WebForm是微软B/S端的两条腿,两种不同的设计理念,相对来说MVC更优于WebForm对于大数据的交互,因为WebForm是同一时间传输所有数据,而MVC它只是传输所用到的数据,更精确, ...

  5. (读书笔记)Asp.net Mvc 与WebForm 混合开发

    根据项目实际需求,有时候会想在项目中实现Asp.net Mvc与Webform 混合开发,比如前台框架用MVC,后台框架用WebForm.其实要是实现也很简单,如下: (1)在MVC 中使用Webfo ...

  6. ASP.NET MVC与WebForm区别

    [转贴一] 使用ASP.NET MVC框架,创建默认项目,第一直观感觉就是地址都是Rewrite过的.对源码和配置文件稍加分析不难看出,MVC使用了httpModules来拦截地址请求,具体用到了Sy ...

  7. MVC与WebForm的一些区别

    MVC与WebForm的一些区别 它们都是ASP.NET WEB开发的两种方式 .但是他们也是有一些不同.做个小结. 1.MVC是没有服务器端控件这么一说的,也就是没有viewstate,也就不会产生 ...

  8. MVC与WebForm最大的区别

    原文地址:http://www.cnblogs.com/birdshover/archive/2009/08/24/1552614.html 使用ASP.NET MVC框架,创建默认项目,第一直观感觉 ...

  9. MVC与WebForm的简单的比较

    MVC与WebForm的简单的比较 ASP 强制程序员将业务逻辑和展示页放到一个文件中 WebForm 允许程序员将业务逻辑与页面展示分开到不同的文件中,并且提供强大的开发平台来写  业务逻辑代码  ...

随机推荐

  1. C#实现哥德巴赫猜想

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Goet ...

  2. Sql Server系列:视图

    视图是数据库中的一种虚拟表,与真实的表一样,视图包含一系列带有名称的行和列数据.行和列数据用来自定义视图的查询所引用的表,并且在引用视图时动态生成. 1. 视图的概念 视图是从一个或者多个表中导出的, ...

  3. canvas学习笔记一

    为了研究pixi库,就顺带从头到位学习下canvas吧 判断支持力度 var webgl = (function() { try { var canvas = document.createEleme ...

  4. MVC4做网站后台:栏目管理1、添加栏目-续

    栏目类型跟原来一样分为常规栏目.单页栏目和外部链接.根据栏目类型的不同要隐藏相应的表单和验证(服务器端验证).另外一个是父栏目必须是常规栏目才行,easyui-combotree要用到树形json数据 ...

  5. 深入理解脚本化CSS系列第一篇——脚本化行内样式

    × 目录 [1]用法 [2]属性 [3]方法 前面的话 脚本化CSS,通俗点说,就是使用javascript来操作CSS.引入CSS有3种方式:外部样式,内部样式和行间样式.本文将主要介绍脚本化行间样 ...

  6. 我被比特币撞了一下腰——记OKCoin试用体验

    本博客还有大量的.NET开源技术文章,您可能感兴趣: 1.开源Math.NET基础数学类库使用系列文章:链接 2.开源C#彩票数据资料库系列文章:链接 3.开源的.NET平台ORM组件文章:链接 4. ...

  7. 将 instance 连接到 second_local_net - 每天5分钟玩转 OpenStack(85)

    今天是 local network 的最后一个小节,我们将验证两个local network 的连通性. launch 新的 instance “cirros-vm3”,网络选择 second_loc ...

  8. 连接第二个 insance 到 first_local_net - 每天5分钟玩转 OpenStack(83)

    上一节在 first_local_net 中已经部署了 cirros-vm1,今天将再部署一个instance,并验证两个 instance 的连通性. 以同样的方式 launch instance ...

  9. 应用程序框架实战十八:DDD分层架构之聚合

    前面已经介绍了DDD分层架构的实体和值对象,本文将介绍聚合以及与其高度相关的并发主题. 我在之前已经说过,初学者第一步需要将业务逻辑尽量放到实体或值对象中,给实体“充血”,这样可以让业务逻辑高度内聚, ...

  10. 从零开始编写自己的C#框架(2)——开发前准备工作

    没想到写了个前言就受到很多朋友的支持,大家的推荐就是我最大的动力(推荐得我热血沸腾,大家就用推荐来猛砸我吧O^-^O),谢谢大家支持. 其实框架开发大家都知道,不过要想写得通俗点,我个人觉得还是挺吃力 ...