ASP.NET-MVC开发基础1

MVC:简单的来说就是Model层(实体层)、View层(视图层)、Controllers层(控制器)

相比以前的三层架构,这种开发模式耦合性更低。所谓耦合性:就是各个功能模块处理各自的操作,互不干扰,独立性更加高,数据处理维护也就相对的方便。这是我的一个理解。

创建一个MVC项目后,里面有几个文件需要解释一下。

1.App_Start(配置文件夹)

它里面有三个.cs类 第一个是BundelConfig.cs,打包器(打包专用)的配置文件,里面主要是一些CSS,js文件

第二个是FilterConfig.cs,过滤器

最后一个是RouteConfig.cs,路由配置,自动配置了controller和action,通过controller来找到对应的action

2.Controller和view文件夹

简单的来说就是每创建一个控制器,在view文件夹下会有对应的与控制器同名的文件夹。

在控制器中存在一个ActionResult方法,方法名与其对应的view下面有一个同名的.cshtml页面,

我们可以通过调用不同的Action方法,来显示不同的页面内容。

总的来说,它的执行过程是这样的。由地址栏访问控制器-->通过Model过滤校验-->在view中显示。

View文件夹下面还有一个Shared文件这个文件下面有一个_Layout.cshtml它是一个完整的页面。

如果知道三层中的母版页,就会理解它的作用。实际上_Layout就是一个母版页。它通过@RenderBody来替换(相当于内容页)的主体内容。

在Shared文件夹外面还有一个单独的_ViewSatrt.cshtml。在这个里面就一句话

实际上它就是我们的母版页,所有页面都会套用这个母版页

如果需要单独作为一个页面处理,不需要母版页,可以在内容页加上这样一行代码


设置Layout="也可以设置另一个母版页路径";



注:在配置文件web.config中,找到


debug表示调试,当我们改为false时,表示此项目状态是发布的。那么会造成打包器中设置的样式


注:ASP.NET IIS管道问题

在MVC执行过程中,控制器对应的Action方法在调用时,是不需要开发人员手动去实例化的,

原因就是ASP.NET的框架自动处理了这些问题



MVC中的几个内置对象

1.Request

Request,简单来说就是请求的意思。服务器接收客户端的数据

Request.QueryString-->针对表单并且为get的提交方式

Request.Form-->看到Form就想到了表单,这种方式与前者get对应的是post的提交方式

Request.File,获取post提交的文件(文件上传)

文件上传需要注意的是一个需要在表单加一个属性enctype="multipart/form-data"

Request.MapPath,在上传文件的过程中将虚拟路径(相对路径)转换为物理路径(绝对路径)


2.Session

Session俗称会话。 它有几个比较重要的特点:储存在服务器上、安全性较高、性能较差、储存少量重要数据

例如:身份验证(登录账号、密码等)。每个用户登录会拥有独立的Session值,互不干扰。存活时间是20分钟。销毁Session可以调用Abandon()方法或者Clear()方法


3.Cookie

相比Session,Cookie的特点就显而易见了,安全性较低,原因主要是,Cookie它是存储在客户端的数据,用户可以更改内容。并且Cookie还有一个特点就是时效性。可以通过Expires设置Cookie的存活时间。同样也可以销毁存储在客户端的Cookie

使用过期的方式做到清除Cookie




数据的传递

1.从控制器--》视图

通过ViewBag,将ViewBag作为一个贯穿视图和控制器的一个桥梁

通过@在对应的view页面输出


注:ViewBag实际上是一个动态的类型 Content相当于变量,你也可以把它当做 js 中的 var 

通过ViewData。本质上ViewBag也是ViewData集合,也就是说他们的存储方式是一样的。两种方式一般存放一般不主要数据。

通过TempData。TempData和Session相似,通过键值对读取存储。当时TempData在读取后悔会被清空,与ViewData不同的是TempData是可以跨页面的,但是只能用一次。 

那主要的数据是通过什么传递的呢

来讲讲 return View()

View实际上是一个重载方法,控制器中的View可以传递一个Object类型的参数,也就是说可以是Model类中的对象。


那怎么在View视图去接收呢?


通过@Model的方式

实际上在调用Student类中的属性时是没有提示的,我们可以在视图加上这样一行代码


这样就是告诉视图,我传过来的是Model中Student实体类对象,这样它就知道可以通过调用属性的方式拿到数据。如果不加这一行代码它就是一个弱类型视图,加上就是强类型视图。

需要注意的是,由于View有多个参数,在向视图层传值的过程中,参数值不一定是在ActionResult对应的方法里面显示,为什么呢?


参数1:表示你要将Student这个对象传递到指定的视图,并非一定是AcionResult对应的ShowData这个视图。尽管路径依然是/ShowData!

还可以针对母版页传递第二个参数。


_Layout1 就是修建的一个母版页


2.从视图--》控制器


[HttpGet] 表示从视图传数据到控制器限制于Get方式提交,如果使用post会出现404的错误。

通过给Index方法设置参数,不但可以接收get提交的数据,也可以接收post提交的数据。

另一种方式通过实体类来作为参数


这样写有什么好处呢?

在EF设计模型中,我们可以在实体层中给属性进行各种数据校验。


[Required] 表示判断是否为空 Max、Min则是区间值

在控制器层我们需要通过 ModelState.IsValid 来判断Model是否合法。



文件的上传和读取

在action方法里面写入参数 HttpPostedFileBase file ,file我把它看作是变量。


在D盘创建了一个名为uploads的文件夹。通过拼接字符串保存在uploads中。在前面我们也说到了上传文件也可以通过Request.File的方式从客户端接收,并且需要将虚拟路径(相对路径)转换为物理路径(绝对路径)。


同样在使用Form表单时,也需要加上enctype的属性,并且input的name属性必须和 HttpPostedFileBase 变量file一致!当然文件上传不只是上传图片



输出 json 数据


JsonRequestBehavior.AllowGet 可以通过get请求的方式来获取。




再来说说分布式页面的作用吧



创建分布式视图时候,在我看来最大的作用就是可以在不同的地方使用它,只要调用就ok了。类似于 vue 里面的组件。可以重复使用!调用的方法就是


我可以很多次调用。

分布页面也有两种写法:第一种就是待处理的,第二种就是不带处理的。

那什么是待处理的呢? 我刚刚上面的那一种写法就是待处理的。

有与之对应的 ActionResult 方法,在调用的时候可以直接通过 .Action获取对应的分布页面。

另一种不待处理的。


这是我们新建的一个登陆的不待处理的分布页面。注意要遵循不管是分布页面还是布局页面都需要_下划线开头。

与待处理不同的是就是调用的方法。


那怎么传数据呢?

可以通过Model参数,然后在视图层调用即可,User 是新建的实体类。


说一下一个叫MVC 区域 的东西


为什么要设置一个区域呢?在我们的开发过程中,有时候项目过于庞大,如果放在一个MVC项目里面会显得杂乱无章,不清楚哪个是哪个。这个时候我们就可以通过设置区域来建立一个独立的MVC 。如上图所示,Areas文件夹里面有个sport,sport是区域名,下面三个文件夹就是对于的 Controllers、Models、Views。最主要的是它有一个单独的路由


这里需要注意的是,当你返回到最外层的Index首页是它会报如下错误提示。


根据上面的错误提示,我们可以在我最外层的路由上加上这样一行代码。


这样我们就可以通过不同的板块进行区分。

跨路由跳转的问题

简单的来说就是我们需要在最外层给定一个a标签,使其跳转到设置区域对应的模块页面!
在这里由于路由的问题,我们不能够直接写一个a标签跳过去,因为一旦改动路由设置,a标签也必须进行变动,这样会显得非常的繁琐。

我们可以通过系统的a标签来实现!


参数1:表示LinkText也就是显示的名称。

参数2:表示路由的名称,这个可以在对应的区域路由查看,如下图


sport_default就是路由名称

参数3:表示相对应的路由值,也就是区域的控制器名称和action方法名。

这个时候无论你的路由怎么设置,我们都可以成功的实现区域的跳转。



与 @Html.RouteLink 相对应的就是 @Html.ActionLink

@Html.ActionLink就是当前路由跳转


最后来看看ViewModel的一些规则


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容