首页 技术 正文
技术 2022年11月15日
0 收藏 806 点赞 3,485 浏览 2491 个字

  记得2011年mvc3刚出来的时候,我们就有幸将 mvc3 用在我们团购项目上,当时老大让我们用一个星期时间来熟悉mvc,幸好园子里面的老朋友DR

正在写mvc3系列,也恭喜这个系列文章被整理成专题供后来者学习,详见:http://www.cnblogs.com/highend/archive/2011/08/04/aspnet_mvc3_

contents.html,2013年进携程的时候,也开心的看到公司正在将webform升级到mvc3,我们知道mvc在更新到3的时候相比之前已经有了重大的变革,

其中就包括新增的razor模版引擎,大家都知道razor语法简单,容易入手,相比之前的aspx模板在语法简易性上有了很大的提高,这篇就准备从razor入手。

一:随便看看几个razor语法

1. 你要会用 “单行和代码块语法输出”

 1 <h1>
2 第一种方式:</h1>
3 <hr />
4 @DateTime.Now.ToString()
5 <h1>
6 第二种方式:</h1>
7 <hr />
8 @{
9 var @dt = DateTime.Now.ToString();
10 }
11 @dt

asp.net mvc 之旅—— 第一站 从简单的razor入手

2. 你要会用 “逻辑控制语句”

 @for (int i = ; i < ; i++)
{
<h1>@i</h1>
}
@if (DateTime.Now.Ticks / == )
{ }
else
{ }

3. 你要会用 “内容标记块语法”

用text或者@: 来标记内容块开始。

 1 // 第一种方式
2 @if (true)
3 {
4 @: 结束 @DateTime.Now.ToString()
5 }
6 <hr />
7
8
9 //第二种方式
10 @if (true)
11 {
12 <text> 结束 @DateTime.Now.ToString() </text>
13 }

4.你要会用“将model从controller中传递到view”

1. Controller代码

     public class HomeController : Controller
{
public ActionResult Index()
{
var student = new Student() { Name = "ctrip", Age = }; return View(student);
} public ActionResult About()
{
return View();
}
}

2. View代码

 @model MvcApplication1.Models.Student <h1>姓名: @Model.Name</h1> <h1>年龄: @Model.Age</h1>

  

   好了,如果你知道上面四点的话,恭喜你,razor这辆车你基本上算是会开了。。。但是会开车不见得就懂车,下面我们来看看razor到底是什么???

二:剖析Razor

   我们知道C#是托管语言,既然是托管语言,那就需要将C#的代码编译成IL语言并封装到DLL中。。。对吧,同样的道理,Razor编译后也会生成

DLL。。。那下面一个问题来了,DLL在哪里?会是什么样的组织形式???

1. DLL在哪里?

  首先我们把实例代码跑起来,如下图:

asp.net mvc 之旅—— 第一站 从简单的razor入手

然后查看Index.cshtml页面生成的临时文件:C:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files

asp.net mvc 之旅—— 第一站 从简单的razor入手

看到了没有,pdb已经见红了,这个所谓的App_Web_xxxx.dll 就是我们View生成的临时dll,下一步我们用ILSpy看看这个dll里面到底

有什么???

asp.net mvc 之旅—— 第一站 从简单的razor入手

从上面的图中,我们大概看到如下几点:

第一:我们的Index.cshtml 对编译器来说仅仅是一个类(__Page_Views_Home_Index_cshtml)而已。。。毫无神秘之感。。。

第二:我们的Html标签,例如h1的展示,对编译器来说仅仅是调用WriteLiteral方法而已。。。

第三:我们的类是继承于WebViewPage<Student>,你要是够细心,你会发现这里的T(Student)正是我往View中塞的student实体。

三:深入追究

1. WebViewPage<TModel>类

  既然WebViewPage是基类,那下一个问题就比较好奇了,因为我们知道子类可以继承父类所有public的方法,对吧,那下一步我们就看

看这个类中有哪些方法?

asp.net mvc 之旅—— 第一站 从简单的razor入手

从上图中是不是看到了两个有趣的属性,Html和Model。

1. Html

  首先我们知道它就是HtmlHelper类型,通常我们在Mvc中写html标签的方法有两种,第一种方法就是原生的html标签,还有一种那就是WebViewPage

提供的各种htmlhelper,是不是很有意思???

  asp.net mvc 之旅—— 第一站 从简单的razor入手

2. Model

还记得我们在写View的时候,使用@Model.Name展示姓名,用@Model.Age来展示年龄,那这个Model就是WebViewPage定义的属性,对吧,

下面我们继续用ILSpy看看@Model是如何取值的!!!

asp.net mvc 之旅—— 第一站 从简单的razor入手

从上图中我们可以看到取的原来是ViewData.Model。。。然后我们看看Controller中的View(object obj)中的obj是最后给谁传值的。。。

         public ActionResult Index()
{
var student = new Student() { Name = "ctrip", Age = }; return View(student);
}

asp.net mvc 之旅—— 第一站 从简单的razor入手

asp.net mvc 之旅—— 第一站 从简单的razor入手

通过上面的图,现在我们终于知道了。。。原来View(xxx)最终还是给 ViewData.Model赋值的。。。换句话说我可以在Action中直接给ViewData.Mode

l赋值不是一样的么???说干就干。

         public ActionResult Index()
{
var student = new Student() { Name = "ctrip", Age = }; ViewData.Model = student; return View();
}

asp.net mvc 之旅—— 第一站 从简单的razor入手

原来我拉出来写是一样的效果。。。好了,其实父类还有很多,每个类中我相信你都会找到很多熟悉的属性和方法,就比如:WebPageBase类中的

Layout,Page,RenderBody等等。。。更好细节,期待你去发现。

asp.net mvc 之旅—— 第一站 从简单的razor入手

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,909
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,434
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,249
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,060
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,692
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,730