一步一步使用Ext JS MVC与Asp.Net MVC 3开发简单的CMS后台管理系统之创建项目
打开VS2012,在主菜单选择文件,新建,项目,在如图1所示的弹出窗口中已安装的模板下选择C#的Web模板,然后选择“ASP.NET MVC 3 Web应用程序”,将项目名称修改为SimpleCMS,单击确定按钮后将显示如图2的窗口。
图1 新建项目窗口
图2 新建MVC 3项目
在图2窗口中,确保模版为空模板,视图引擎为Razor,最后单击确定按钮完成项目的创建。
创建项目后,首先要做的是在解决方案资源管理器中将解决方案Content和Scripts目录下的文件全部删除,然后在Content目录下创建一个 Images目录,在Scripts目录下创建app和ExtJS两个目录。在app目录下,再创建controller、model、store和 view这4个目录,分别用来存放项目中Ext JS的控制器、模型、Store和视图文件。再在ExtJS目录下创建一个ux目录,用来存放Ext JS的扩展组件。
管理系统将使用最新版本的Ext JS,也就是4.1.1版本,在Ext JS 4.1.1包中将bootstrap.js、ext-all.js和ext-all-dev.js(现在bootstrap.js在调试时加载的是该文件 而不是ext-all-debug.js文件)这三个文件和resources目录复制到解决方案的ExtJS目录下。这里要注意,千万不要直接复制到项 目的实际目录下,不然打包的时候,如果不进行额外设置,这些文件将不会包含在发布包里,因而最好的方式是在解决方案资源管理器中进行复制。
还要将local目录下的中文语言包ext-lang-zh_CN.js也复制到ExtJS目录下。如果项目要支持多语言,可以在ExtJS目录下创建一个local目录用来存放语言包,在这里不需要,因为直接复制到ExtJS目录就可以了。
最后,在Ext JS包目录内搜索s.gif文件,将其复制到Content目录下的Images目录。
最终结果将如图3所示。
图3 搭建Ext JS开发框架
Ext JS的框架已经搭建好了,现在需要测试一下ExtJS是否能正常使用,并顺便创建首页。在Controllers目录新建一个HomeController控制器,将会看到如下代码:
[csharp]
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
namespace SimpleCMS.Controllers
{
public class HomeController : Controller
{
//
// GET: /Home/
public ActionResult Index()
{
return View();
}
}
}
在代码中的View上单击鼠标右键,在弹出菜单中选择添加视图,将看到如图4所示的窗口。
图4 为首页添加视图
将图中“使用布局或母版页”这个选项去掉,因为要实现的是单页面的应用程序,不需要布局或母版页,最后单击添加按钮,将看到如下的代码:
[html]
@{
Layout = null;
}
<!DOCTYPE html>
<html>
<head>
<title>Index</title>
</head>
<body>
<div>
</div>
</body>
</html>
将title中的Index修改为“CMS后台管理系统”,并在其下面添加页面编码说明及Ext JS样式和脚本的引用,代码如下:
[html]
<title>CMS后台管理系统</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link rel="stylesheet" type="text/css" href="@Url.Content("Scripts/extjs/resources/css/ext-all.css")" />
<script type="text/javascript" src="@Url.Content("Scripts/extjs/bootstrap.js")"></script>
<script type="text/javascript" src="@Url.Content("Scripts/extjs/Ext-lang-zh_CN.js")"></script>
然后将body中的div删除,添加一个script块,在块内添加Ext.onReady函数块,代码如下:
[javascript]
<script>
Ext.onReady(function () {
})
</script>
在onReady函数内先添加空白图片的验证,这里要注意图片的目录,具体代码如下:
[javascript]
if (Ext.BLANK_IMAGE_URL.substr(0, 4) != "data") {
Ext.BLANK_IMAGE_URL = "Content/Images/s.gif";
}
最后,调用Ext JS的alert显示一个提示信息,代码如下:
[javascript]
Ext.Msg.alert("提示信息", "你好!");
现在在主菜单选择调试,开始执行(不调试),或直接按Crrl+F5,在浏览器浏览项目,如果显示如图5所示提示信息,表示一切正常,可以进入具体开发 了。不过,还有点小事情要解决,就是要将ext-all.css文件中,所有“11px”的修改为“12px”,不然字体太难看。