紧跟时代步伐,让我们拥抱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语法一定会带给你很多的惊喜

 

 

 

我又回来了,回到了技术最前线,
相关文章
|
1天前
|
人工智能 运维 安全
|
4天前
|
SpringCloudAlibaba 负载均衡 Dubbo
微服务架构下Feign和Dubbo的性能大比拼,到底鹿死谁手?
本文对比分析了SpringCloudAlibaba框架下Feign与Dubbo的服务调用性能及差异。Feign基于HTTP协议,使用简单,适合轻量级微服务架构;Dubbo采用RPC通信,性能更优,支持丰富的服务治理功能。通过实际测试,Dubbo在调用性能、负载均衡和服务发现方面表现更出色。两者各有适用场景,可根据项目需求灵活选择。
377 124
微服务架构下Feign和Dubbo的性能大比拼,到底鹿死谁手?
|
6天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
637 107
|
3天前
|
Java 数据库 数据安全/隐私保护
Spring 微服务和多租户:处理多个客户端
本文介绍了如何在 Spring Boot 微服务架构中实现多租户。多租户允许单个应用实例为多个客户提供独立服务,尤其适用于 SaaS 应用。文章探讨了多租户的类型、优势与挑战,并详细说明了如何通过 Spring Boot 的灵活配置实现租户隔离、动态租户管理及数据源路由,同时确保数据安全与系统可扩展性。结合微服务的优势,开发者可以构建高效、可维护的多租户系统。
200 127
|
3天前
|
Web App开发 前端开发 API
在折叠屏应用中,如何处理不同屏幕尺寸和设备类型的样式兼容性?
在折叠屏应用中,如何处理不同屏幕尺寸和设备类型的样式兼容性?
226 124
|
3天前
|
人工智能 数据可视化 测试技术
Coze平台指南(3):核心功能-创建智能体与设计角色
Coze 智能体是由大语言模型驱动,通过提示词设定角色,并借助知识库、插件和工作流扩展能力,以执行特定任务的AI助手。对测试工程师而言,精心设计的智能体可显著提升测试效率与质量,关键是要准确理解测试需求,并将其转化为智能体的角色设定和功能配置。建议进一步学习知识库与工作流,以深化应用。
|
7天前
|
JSON fastjson Java
FastJson 完全学习指南(初学者从零入门)
摘要:本文是FastJson的入门学习指南,主要内容包括: JSON基础:介绍JSON格式特点、键值对规则、数组和对象格式,以及嵌套结构的访问方式。FastJson是阿里巴巴开源的高性能JSON解析库,具有速度快、功能全、使用简单等优势,并介绍如何引入依赖,如何替换Springboot默认的JackJson。 核心API: 序列化:将Java对象转换为JSON字符串,演示对象、List和Map的序列化方法; 反序列化:将JSON字符串转回Java对象,展示基本对象转换方法;