跟我一起学习ASP.NET 4.5 MVC4.0(六)

简介: 原文http://www.cnblogs.com/xdotnet/archive/2012/07/21/aspnet40_webpage20.html这一系列文章跨度有点大,由于最近忙于其他事情,没有更新,今天重新安装了下Win8系 统,VS2012和SQLServer 2012,顺便抽空继续一篇。

原文http://www.cnblogs.com/xdotnet/archive/2012/07/21/aspnet40_webpage20.html

这一系列文章跨度有点大,由于最近忙于其他事情,没有更新,今天重新安装了下Win8系 统,VS2012和SQLServer 2012,顺便抽空继续一篇。随着VS2012 RC版本的放出,ASP.NET MVC4.0也随之有所改变,主要相对于BETA版本。前面几章节都是介绍MVC4.0或者是3.0中内容,今天我们来了解一下WebPage 2.0下面的一些变化。在MVC3.0中使用的是WebPage 1.0版本,这里主要是介绍一下在MVC4.0中对脚本以及样式表的引用变化等等。

 

一、可以直接使用“~”,而无需使用Href对象实例

这个是一大变化,给我们ASP.NET MVC开发人员带来了很便捷的代码书写方式,提高不少效率。在MVC3.0中加入我们需要加入一张图片时,需要在IMG标签的SRC属性加上 Url.Content或Href对象方法等来对路径进行解析。在WebPage 2.0中Razor模板引擎能够自动解析基于根目录的路径,即可以直接使用“~”来表示根目录。

 MVC3:

<href="@Href("~/Default.cshtml")">Home</a> 

MVC4:

< href ="~/Default.cshtml" >Home </ a >

 

 

二、CheckBox等可以根据Value自动隐藏checked属性

 在以前初始化一个CheckBox是否被选中,都需要额外写一个方法来判断是否在INPUT的CheckBox中加入checked属性。在MVC4.0中这个将被改变,这也是一个很赞的改进,具体可以看如下代码。

MVC3:

 1 <input type="checkbox"

2  name ="check1"
3  value ="check1"
4  @if(checked1){<text >checked="@checked1" </ text >} />

MVC4:

 1 <input type="checkbox"

2  name ="check1"
3  value ="check1"
4  checked ="@checked1"  />

 只要checked1变量为false或null,将会隐藏checked属性,是不是一个很好的改进!!

 

三、使用System.Web.Optimization对脚本和样式表的操作

这个也是本章重点向描述的部分,首先我们可以使用VS2012RC来新建一个MVC4.0项目,版本可以为4.0或4.5。在 Global.asax文件代码中,我们发现已经把过滤器,路由器,以及对样式表和脚本捆绑(Bundles)移到了其他页面,就是在根目录下的 App_Start文件夹内。代码只是简简单单的几行,代码如下:

复制代码
 1  using System;
 2  using System.Collections.Generic;
 3  using System.Configuration;
 4  using System.Data.Entity;
 5  using System.Data.Entity.Infrastructure;
 6  using System.Linq;
 7  using System.Web;
 8  using System.Web.Http;
 9  using System.Web.Mvc;
10  using System.Web.Optimization;
11  using System.Web.Routing;
12 
13  namespace MVC4
14 {
15      //  Note: For instructions on enabling IIS6 or IIS7 classic mode, 
16       //  visit  http://go.microsoft.com/?LinkId=9394801
17 
18      public  class MvcApplication : System.Web.HttpApplication
19     {
20          protected  void Application_Start()
21         {
22             AreaRegistration.RegisterAllAreas();
23 
24             FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
25             RouteConfig.RegisterRoutes(RouteTable.Routes);
26             BundleConfig.RegisterBundles(BundleTable.Bundles);
27         }
28     }
29 }
复制代码

而在App_Start目录下多了3个文件,他们分别是RilterConfig.cs,RouteConfig.cs以及 BundleConfig.cs文件。在BETA版本中还是直接写在Global.asax文件中,从名称上就可以知道他们各自的功能,今天我们主要了解 BundleConfig.cs文件的内容和功用。

 

在BundleConfig.cs文件中,包含了一些应用程序中使用的脚本和样式表的文件路径,其中可以使用通配符,具体代码如下所示:

复制代码
 1  using System.Web;
 2  using System.Web.Optimization;
 3 
 4  namespace MVC4
 5 {
 6      public  class BundleConfig
 7     {
 8          public  static  void RegisterBundles(BundleCollection bundles)
 9         {
10             bundles.Add( new ScriptBundle( " ~/bundles/jquery ").Include(
11                          " ~/Scripts/jquery-1.* "));
12 
13             bundles.Add( new ScriptBundle( " ~/bundles/jqueryui ").Include(
14                          " ~/Scripts/jquery-ui* "));
15 
16             bundles.Add( new ScriptBundle( " ~/bundles/jqueryval ").Include(
17                          " ~/Scripts/jquery.unobtrusive* ",
18                          " ~/Scripts/jquery.validate* "));
19 
20             bundles.Add( new ScriptBundle( " ~/bundles/modernizr ").Include(
21                          " ~/Scripts/modernizr-* "));
22 
23             bundles.Add( new StyleBundle( " ~/Content/css ").Include( " ~/Content/site.css "));
24 
25             bundles.Add( new StyleBundle( " ~/Content/themes/base/css ").Include(
26                          " ~/Content/themes/base/jquery.ui.core.css ",
27                          " ~/Content/themes/base/jquery.ui.resizable.css ",
28                          " ~/Content/themes/base/jquery.ui.selectable.css ",
29                          " ~/Content/themes/base/jquery.ui.accordion.css ",
30                          " ~/Content/themes/base/jquery.ui.autocomplete.css ",
31                          " ~/Content/themes/base/jquery.ui.button.css ",
32                          " ~/Content/themes/base/jquery.ui.dialog.css ",
33                          " ~/Content/themes/base/jquery.ui.slider.css ",
34                          " ~/Content/themes/base/jquery.ui.tabs.css ",
35                          " ~/Content/themes/base/jquery.ui.datepicker.css ",
36                          " ~/Content/themes/base/jquery.ui.progressbar.css ",
37                          " ~/Content/themes/base/jquery.ui.theme.css "));
38         }
39     }
40 }
复制代码

这些都是关于Bundle的应用,从代码中就可以看到,Bundle实例对象(Script和Style)中包含一个虚拟目录,这个目录可以在页面 中使用时作为唯一键引入。当然在实现优化时,这个虚拟目录将呈现在前台页面中,这个后面将继续讲述。下面我们来看一下在代码中如何使用他们,在 System.Web.Optimization程序集中包含了Scripts和Styles两个类,分别用于呈现Bundle集合中的脚本和样式表,代 码如下:

1         @Styles.Render( " ~/Content/themes/base/css "" ~/Content/css ")
2         @Scripts.Render( " ~/bundles/modernizr ")

从上面就可以看出,往页面中引入了两个捆绑的样式表和一个脚本,这些引入是包含了所有Include方法内的文件,调试一下看看前台HTML代码就知道了。而他们中的另一个方法Url则是对外部文件的引入,例如CDN中的文件,如:Google等等API文件。

 

四:对样式表和脚本的优化

这项其实也是包含在三中的,我独立出来,最主要感觉是我觉得他是个不错的家伙。代码简单,但是非常的适用,不知道大家有没有使用过 AjaxMinify这个东东,可以把脚本编译,压缩成最小的内容。不过都是要使用命令的,然而在MVC4.0中 System.Web.Optimization已经包含了这个东东,他们就是JsMinify和CssMinify,不要小看这两个类,虽然公开的方法 就两个。

按照上述方法是用Scripts和Styles将脚本和样式表引入页面时,无需修改任何代码就可以将脚本和样式表编译压缩输入到客户端,这样不仅可 以有效的增加JSHack的难度以及降低文件的大小。为了达到这个目的,我们只需要将BundleTable中的一个属性设置为true即可,代码如下:

复制代码
 1  using System;
 2  using System.Collections.Generic;
 3  using System.Configuration;
 4  using System.Data.Entity;
 5  using System.Data.Entity.Infrastructure;
 6  using System.Linq;
 7  using System.Web;
 8  using System.Web.Http;
 9  using System.Web.Mvc;
10  using System.Web.Optimization;
11  using System.Web.Routing;
12 
13  namespace MVC4
14 {
15      //  Note: For instructions on enabling IIS6 or IIS7 classic mode, 
16       //  visit  http://go.microsoft.com/?LinkId=9394801
17 
18      public  class MvcApplication : System.Web.HttpApplication
19     {
20          protected  void Application_Start()
21         {
22             AreaRegistration.RegisterAllAreas();
23             
24             FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
25             RouteConfig.RegisterRoutes(RouteTable.Routes);
26             BundleTable.EnableOptimizations = true;
27             BundleConfig.RegisterBundles(BundleTable.Bundles);
28         }
29     }
30 }
复制代码

是不是很神奇啊,上面红色字体的就是我们要加入的一行代码。关于ASP.NET 4.5 MVC 4.0还有很多值得我们去挖掘,由于我不是一个专业的学术研究者,写的文章不够有条理,思路都是想到那些到哪,没有时间来规范这个从易到难或什么的来书 写,给各位带来不好的浏览效果表示歉意。

 

 

关于作者:网魂小兵

文章出处:http://xdotnet.cnblogs.com

本文可以随意转载,摘抄等非商业用途。

为了尊重作者成果,在转载和摘抄的时候请留下作者名称和出处。

 
目录
相关文章
|
6天前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
19 7
|
4天前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
13 0
|
28天前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
29 0
|
29天前
|
开发框架 前端开发 安全
ASP.NET MVC 如何使用 Form Authentication?
ASP.NET MVC 如何使用 Form Authentication?
|
Web App开发 前端开发 .NET
艾伟_转载:学习 ASP.NET MVC (第五回)理论篇
本系列文章导航 学习 ASP.NET MVC (第一回)理论篇 学习 ASP.NET MVC (第二回)实战篇 学习 ASP.NET MVC (第三回)实战篇 学习 ASP.NET MVC (第四回)实战篇 学习 ASP.NET MVC (第五回)理论篇 通过前几篇文章,我们通过ASP.NET MVC创建了一个简单的应用程序,学习了ASP.NET MVC的基本框架和工作流程。
1080 0
|
Web App开发 前端开发 .NET
艾伟_转载:学习 ASP.NET MVC (第一回)理论篇
本系列文章导航 学习 ASP.NET MVC (第一回)理论篇 学习 ASP.NET MVC (第二回)实战篇 学习 ASP.NET MVC (第三回)实战篇 学习 ASP.NET MVC (第四回)实战篇 学习 ASP.NET MVC (第五回)理论篇 MVC三种角色:--Model:用于存储数据的组件--View:根据Model数据进行内容展示的组件--Controller:接受并处理用户指令(操作Model),选择一个View并输出内容。
1078 0
|
1月前
|
开发框架 .NET
Asp.Net Core 使用X.PagedList.Mvc.Core分页 & 搜索
Asp.Net Core 使用X.PagedList.Mvc.Core分页 & 搜索
79 0
|
4月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
144 0
|
4月前
|
开发框架 前端开发 JavaScript
JavaScript云LIS系统源码ASP.NET CORE 3.1 MVC + SQLserver + Redis医院实验室信息系统源码 医院云LIS系统源码
实验室信息系统(Laboratory Information System,缩写LIS)是一类用来处理实验室过程信息的软件,云LIS系统围绕临床,云LIS系统将与云HIS系统建立起高度的业务整合,以体现“以病人为中心”的设计理念,优化就诊流程,方便患者就医。
63 0
|
4月前
|
开发框架 前端开发 .NET
C# .NET面试系列六:ASP.NET MVC
<h2>ASP.NET MVC #### 1. MVC 中的 TempData\ViewBag\ViewData 区别? 在ASP.NET MVC中,TempData、ViewBag 和 ViewData 都是用于在控制器和视图之间传递数据的机制,但它们有一些区别。 <b>TempData:</b> 1、生命周期 ```c# TempData 的生命周期是短暂的,数据只在当前请求和下一次请求之间有效。一旦数据被读取,它就会被标记为已读,下一次请求时就会被清除。 ``` 2、用途 ```c# 主要用于在两个动作之间传递数据,例如在一个动作中设置 TempData,然后在重定向到另
253 5