博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ASP.NET MVC 原理
阅读量:6686 次
发布时间:2019-06-25

本文共 1140 字,大约阅读时间需要 3 分钟。

我出了份卷子做面试题,其中之一就是要求说说ASP.NET MVC的原理。感觉太空泛了,谁能说得准呢?

但是,如果站在我这个面试官立场,面试题好多时并不要求有标准答案,可能也没有什么标准答案,主要是通过问答,了解一下面试者的理解程度,相关知识程度什么的。其实,我自己水平也不行,但因为年纪大,好像不带点人大家会觉得有点怪怪的,所以过去一段时间也参与点招聘工作。

对于ASP.NET MVC,我自己的理解是酱紫的:

MVC是一种思想。ASP.NET MVC只不过是实现了这种思想的一种开发框架。利用Web Form项目,其实也可以实现MVC。以前搞WEB FORM,我就试过MVP模式。

MVC的思想要点的在于将UI和业务逻辑、数据分离。好处一是逻辑清晰,二是有利于逻辑重用和测试。因为UI很难自动化测试,但逻辑却可以。所以说,ASP.NET MVC有利于进行单元测试。并且UI与逻辑、数据分离以后,也容易重用。比如说,在ASP.NET MVC中,不同的action可以指向同一个view。

经典的MVC中,Model是个巨无霸,包含业务逻辑和数据。controller只是一个中间人,在View和Model之间传递点什么,打打酱油。有时候,Model和View甚至直接联系,绕开了controller。

而在ASP.NET MVC中,虽然有一个Model,但此Model并非彼巨无霸Model。ASP.NET MVC中的Model,是一个跟视图有关的Model,也就是传说中的那个VM,ViewModel,它只是经典巨无霸Model的一部分。ViewModel,顾名思义,主要用于View。经典巨无霸Model,被拆分成了数据(ViewModel、领域对象、数据库实体类 )+ 业务逻辑(BLL ,各种Service)。因此,Model只不过是一群概念的集合,并不是一个实实在在的对象。

值得一提的是,ViewModel、领域对象、数据库实体类很有可能是同一个对象。比如说,我们在View里直接操作的VM,其实常常就是将数据持久层的实体类直接拿过来用的。即便如此,但在软件设计阶段,还是要将它们的概念区分开。

ASP.NET MVC的原理,其实就是使用HttpModule和HttpHandler将用户的请求拦截,按照设定的路由规则解释到相应的控制器和Action,加以执行。Module是一个比较宏观一点的概念,像Session、Cache都由相应的Module负责;而Handler就是负责处理具体请求的。先有Module,再有Handler。它们的关系,有点像进程和线程。

转载于:https://www.cnblogs.com/leftfist/p/6808772.html

你可能感兴趣的文章
qsort函数辅助函数compare函数的编写
查看>>
项目选题报告答辩总结模板
查看>>
最小费用最大流
查看>>
uva 10972 RevolC FaeLoN
查看>>
玩转Android之Drawable的使用
查看>>
C#中的单例模式
查看>>
全局变量
查看>>
迷茫的程序员
查看>>
android号码匹配位数修改
查看>>
基于 DirectX11 的 MMDViewer 02-创建一个窗口
查看>>
Repository 设计模式介绍
查看>>
mysql的下载与安装
查看>>
只是一个文件节点类为了项目的数据处理
查看>>
十七进制转换为十进制的C语言程序
查看>>
单线程的弊端,多线程基础学习
查看>>
你真的会玩SQL吗?玩爆你的数据报表之存储过程编写(下)
查看>>
JavaScript基础知识整理
查看>>
ThinkPhp3.2.3 使用phpExcel导入数据
查看>>
MSIL 心得
查看>>
linux获得目录下文件个数
查看>>