紧跟时代步伐,让我们拥抱MVC 3

简介: 作为一个开发者,我们不希望技术很快的更新,这是因为我们还没有完全掌握原来技术的基础上,又要掌握新的技术,作为天天忙忙碌碌的程序员,我们不希望还要额外的时间来学习,尤其是当我们的年龄,逐渐的变大的时候,但是有时候跟上时代的步伐也会给我们带来很多的好处,我今天要说的主题就是让我们从MVC 2 升级到 MVC3 吧,因为他带给我们太多的是惊喜,而不是学习的苦恼。

作为一个开发者,我们不希望技术很快的更新,这是因为我们还没有完全掌握原来技术的基础上,又要掌握新的技术,作为天天忙忙碌碌的程序员,我们不希望还要额外的时间来学习,尤其是当我们的年龄,逐渐的变大的时候,但是有时候跟上时代的步伐也会给我们带来很多的好处,我今天要说的主题就是让我们从MVC 2 升级到

MVC3 吧,因为他带给我们太多的是惊喜,而不是学习的苦恼。

可能有的园友要嗤之以鼻了,每个技术的更新都会带来新的学习点,我们总是要不断的学习来跟上他们,我们会很累的?的确,作为一名程序员,我们每天总是睡得很晚,起的很早,很多人喜欢叫我们夜猫子,因为只有在夜深人静的时候,我们才能投入精神来学习而不被打扰。但是就算我们不想每天这么累,我建议每个MVC人员,从MVC 2 升级到MVC 3 吧,因为他能改善我们很多的工作时间,增加工作效率,甚至会减少很多bug。你不信,那么我们就一起来分析一下,究竟是升级MVC 3带来的好处多,还是浪费我们学习的时间多吧。

asp.net MVC 2发布已经过去了很长时间了,我们也是从它开始来真正的开发我们的网站应用程序的,那么我们想一下,MVC 2 带给我们的有哪些不便之处呢?我来

列举几个比较重要的缺点吧。

  1. 如果你想在MVC 2中控制每个Action 的执行是否会出现异常,你会怎么做呢?你可能的做法就是定义一个可以处理异常的Attribute,然后分别应用到每个Action或者是Controller上,来捕获出现的异常信息?或者还有一种方法就是定义一个基类,让所有的Controller都继承自这个基类,而我们在基类中捕获异常。据我个人所知,大多数人采用的也就是这两种处理异常的方式,但是我们来考虑一下它的缺点。第一个处理异常的方式很明显就是啰嗦,第二个呢,使我们在Web  form时代通用的方式,肯定不错。但是我们从另一个方面来想一下,如果说我们除了要捕获异常信息之外,还要添加验证,那么应该怎么做呢?
    C#是单继承的,这个问题留给园友们来思考?在MVC 3中这个方式得到了解决,就是全局Attribute
  2. 在MVC 2中,如果你想添加一个后台管理系统,你会怎么办呢?其实这个有一个很好的解决办法,就是另外添加一个MVC 应用程序,用来作为后台管理系统?其实这真的是很好的处理方式,虽然我个人没有采用MVC 2开发过任何的系统,但是我还是非常欣赏这种折中的处理方式。但是这同样带来了另外一个问题,所有的资源文件得不到重用,甚至是css文件?你不得不重新建立各个目录来进行存放,还有一个非常直接但是非常重要的问题摆在了面前?htmlhelper类可以在后台管理系统中访问到前台页面吗?我们可以在同一个IIS目录下访问这两个不同的应用程序吗?我想是不能的,首先htmlHelper类中的方法是无法应用到前台页面的,还有在同一个地址中是不可能访问到这两个不同的应用程序的。这会带来非常严重的问题,毕竟在后台无法访问到前面页面就是客户无法接受的问题?我们又能如何处理呢?MVC 3中对应的就是Area
  3. Razor视图也是一个我们不得不提的重要因素,我们都知道MVC 2遵循的是web form时代的<%%>方式,这令我们在前台构造复杂的逻辑分离时是十分痛苦的?如果说你想在前台显示一个列表,那么foreach是我们都会采用的方式,我们知道在foreach中我们会使用到多少个<%%>,这会令我们的程序非常难懂,并且非常容易出错。而Razor视图就是利用@符号作为处理方式,简洁的方式绝对是我们想象不到的好用,只要你用了它,相信你会爱上他。
  4. MVC 3 使用到了Nuget,这是一个非常好的扩展插件,可以自动更新我们程序的引用到它的各个地方,甚至包括web.config配置文件。
  5. 在MVC 3中母板页没有了.master,所有文件的后缀名都是.cshtml,这当然会使我们收益,毕竟只要我们愿意,可以指定任何文件作为母板页,哪怕只是为了单纯的嵌套使用。
  6. MVC 3增强了htmlHelper类,让我们的开发更加的流畅。
  7. 依赖注入一直是我比较喜欢研究的一门技术,当然我现在还没有完全的入门依赖注入,但是我深刻的感受到MVC 3对依赖注入的完美支持,只要你愿意,任何IOC框架都可以应用到MVC 3程序中,从而实现更好的替换功能。

说了这些MVC 2中 相对MVC 3所不具有的缺点,相信你也可以更加感受到MVC 3真的值得我们去学习,虽然说现在MVC 4已经出来了,但是我还是建议你学习一下MVC 3,因为越级的学习会给我们以后的深入带来很大的困扰。虽然说我介绍的很大概,但是我想同是作为程序员的你,一定可以理解我说的是什么意思。尤其是MVC 3 所带来的全局Attribute以及Area两种技术的更新就可以让我们有足够的勇气去面对升级带来的任何麻烦。相信我吧,升级一下自己,带来的可能是更大的收获。

最后,展示一下MVC 3的razor语法,相信你会深深的爱上它。

 1 @{
 2     Layout = "~/views/shared/_layout.cshtml";
 3 }
 4 @using MvcWeb.Extensions
 5 <!DOCTYPE html>
 6 <html>
 7 <head>
 8     <title>Index</title>
 9     <script src="http://www.cnblogs.com/Scripts/jquery-1.5.1.js" type="text/javascript"></script>
10     <script type="text/javascript" src="@Url.Content("http://www.cnblogs.com/Scripts/jquery-1.5.1-vsdoc.js")"></script>
11     <script type="text/javascript" src="@Url.Content("http://www.cnblogs.com/scripts/jquery.validate.js")"></script>
12 </head>
13 <body>
14     <div>
15         <form id="form" action="" method="post">
16         <input type="text" id="user.Name" name="user.Name" />
17         @{  this.Jquery().Validations().Required("user.Name", "用户名是必填的  亲");}
18         <select name="user.Gender">
19             <option value="">Please select...</option>
20             <option value="1">Male</option>
21             <option value="2">Femle</option>
22         </select>
23         @{ this.Jquery().Validations().Required("user.Gender", null);}
24         <input type="text" name="user.Email" />
25         @{this.Jquery().Validations().Element("user.Email").Required("邮箱是必填的").Email("请填写正确的邮箱格式");}
26         <input type="submit" value="提交" />
27         </form>
28         @{
29             @:fdjkfdjkf
30         //  hjkhkjhkj@:fdfdfdf
31             <text>
32             dsdsd
33             dsdsd
34             dsdsd
35             </text>
36           
37         }
38     </div>
39     <script type="text/javascript">
40          @Html.Raw(this.Jquery().Validations().ToScripts("#form"))
41     </script>
42 </body>
43 </html>

razor语法一定会带给你很多的惊喜

 

 

 

我又回来了,回到了技术最前线,
相关文章
|
5月前
|
架构师 安全 前端开发
阿里P9架构师推荐的Spring领域巅峰之作,颠覆了我对Spring的认知
你第一次接触spring框架是在什么时候?相信很多人和我一样,第一次了解spring都不是做项目的时候用到,而是在网上看到或者是听到过一个叫做spring的框架,这个框架号称完爆之前的structs和structs2,吸引了不少人的注意。
|
XML 前端开发 Cloud Native
Spring Framework 5.3.0正式发布,在云原生路上继续发力(下)
Spring Framework 5.3.0正式发布,在云原生路上继续发力(下)
Spring Framework 5.3.0正式发布,在云原生路上继续发力(下)
|
4天前
|
机器学习/深度学习 设计模式 敏捷开发
拥抱变革:我的软件开发演化之旅
【5月更文挑战第7天】 在快速迭代的技术领域,我的成长之路映射了软件工程的演变。本文将通过个人视角,探讨从初学者到资深开发者过程中遭遇的挑战、学习的关键技术和对行业趋势的适应。不同于常规摘要的总结性质,此部分将作为引子,展现技术成长旅程中的思考和感悟。
11 2
|
28天前
|
XML Java 数据格式
注解之光:揭秘Spring注解发展的演进历程
注解之光:揭秘Spring注解发展的演进历程
24 0
注解之光:揭秘Spring注解发展的演进历程
|
5月前
|
运维 Java 微服务
阿里技术专家,紧跟潮流,解读spring微服务架构技术的演进
Spring Cloud是企业进行微服务架构开发的极好选择,为了能帮助大家更好的学习,今天小编给大家推荐一本spring cloud最好的学习书籍。
SpringBoot中的内容协商,颠覆你的认知
本文将介绍 SpringMVC 中内容协商,可能有朋友听过,没听过的估计觉得很陌生,不管怎么样,先告诉你一点,这篇是非常重要的一个知识点,一定不要错误,坚持看完,一定会有大量收获,
|
供应链 小程序 安全
谈谈数字经济时代零售业的成功模式
随着消费者需求不断增长和数字技术的进步,五种零售业的商业模式正蓄势待发:“生态系统参与者”、“规模领先者”、“价值分享者”、“搭便车者”和“区域优势者”不符合这些模式的零售商有失败或被收购的风险。
谈谈数字经济时代零售业的成功模式
|
JavaScript 前端开发
三大框架的现状
一、三大框架一大抄 二、Angular.js: 三、Vue.js: 四、React.js: 五、举例讲解
三大框架的现状
|
Cloud Native Java API
Spring Framework 5.3.0正式发布,在云原生路上继续发力(上)
Spring Framework 5.3.0正式发布,在云原生路上继续发力(上)
Spring Framework 5.3.0正式发布,在云原生路上继续发力(上)