独上高楼网站
  •    你所在位置:首页 VS.netASP.net编程经验〉ASP.NET MVC案例教程(基于ASP.NET MVC beta)第一篇:准备工作
  • ASP.NET MVC案例教程(基于ASP.NET MVC beta)第一篇:准备工作
  • 作者:T2噬菌体  文章来源:博客园  发布日期:2008-11-02  浏览次数:1219
  • 打印这篇文章
  • 摘要
          本文将简要介绍这个文章系列的目的、形式及大体内容。并且完成开始学习这个系列前所必要的准备工作。

    前言
          ASP.NET MVC作为微软官方的MVC解决方案,推出有一段时间了。可以说自动推出以来,一直广受关注。在经历了漫长的Preview之后,前几天终于推出了其beta版。并且在官方文档中,微软声明最终的正式版与beta版相比不会有大的变化。所以,对于.NET平台的开发人员来说,是时候学习ASP.NET MVC了。
          本系列文章作为一个ASP.NET MVC的入门教程,将不会长篇大论介绍其中的概念及理论。而是通过案例实践来学习ASP.NET MVC。在这系列文章中我将逐步完成一个“公告发布系统”。我的写作策略是:先动手做,遇到需要解释概念和理论的时候再解释,而不是先把概念和理论解释完再做东西。
          另外,我还有几点要说明的:
          1.为了将大家的关注点充分集中在ASP.NET MVC上,这个Demo的业务处理将使用Mock的方式。即不会真正去访问数据库,而是虚拟一些数据。
          2.本Demo将不考虑任何美工问题。
          下面,让我们一起开始ASP.NET MVC之旅吧。在这一篇中,我们将做完所有的准备工作。

    配置环境
          如果您还没有安装ASP.NET MVC的话,请到这里下载安装。
          下载后,按提示安装就可以了。

    新建项目
          安装完ASP.NET MVC后,在VS里新建一个项目,可以看到有一个“ASP.NET MVC Web Application”的选项,选择它,新建一个项目,并命名为“MVCDemo”。
          建完项目后,可以看到默认情况下已经建立了很多文件夹,这里简略说一下各个文件夹的作用。
          Content——存放应用需要的一些资源文件,如图片、CSS等。
          Controllers——存放控制器类。
          Models——存放业务模型组件。
          Scripts——存放JavaScript脚本文件。
          Views——存放视图。
          现在不了解一些概念没关系,后续文章将慢慢解释。

    准备工作
          新建完项目后,我们要做的准备工作就是建立Mock业务模型,这样以后我们就直接使用这些“欺骗”式的业务模型进行业务处理,而将全部关注点放在ASP.NET MVC的学习上。
          首先在Models下新建三个文件夹,分别叫做Entities、Interfaces、MockModels,分别用来存放实体类、接口及Mock业务模型。
          Entities下有两个类:CategoryInfo和AnnounceInfo,分别是公告类别和公告的实体类。具体代码如下:
    CategoryInfo.cs:

     1using System;
     2using System.Collections.Generic;
     3using System.Linq;
     4using System.Web;
     5
     6namespace MVCDemo.Models.Entities
     7{
     8    /// 
     9    /// 分类实体类
    10    /// 

    11    public class CategoryInfo
    12    {
    13        public int ID getset; }
    14        public string Name getset; }
    15    }

    16}


    AnnounceInfo.cs:
     

     1using System;
     2using System.Collections.Generic;
     3using System.Linq;
     4using System.Web;
     5
     6namespace MVCDemo.Models.Entities
     7{
     8    /// 
     9    /// 公告实体类
    10    /// 

    11    public class AnnounceInfo
    12    {
    13        public int ID getset; }
    14        public string Title getset; }
    15        public string Content getset; }
    16    }

    17}


          接下来,我们将定义两个接口,分别是公告类别服务和公告服务必须实现的接口。这两个接口放在Interfaces下。
    ICategoryService.cs:
     

    Code


    IAnnounceService.cs
     

    Code


    然后,我们在MockModels下建立两个Mock业务逻辑服务模型。注意它们要各自实现自己的接口。
    MockCategoryService.cs:
     

    Code


    MockAnnounceService.cs
     

    Code


          可以看到,这两个类并没有访问数据库,也没有实现真正的业务逻辑,而不过是“捏造”了一些数据骗骗我们的表示层而已。
          最后,我们要建立一个生成业务逻辑模型的生成器,用来实现表示层和业务逻辑层的解耦。当然,为了简化复杂度,这里没有使用依赖注入机制。下面是我们生成器的代码,这个类是直接放在Models下的。
    ServiceBuilder.cs:
     

    Code


          OK,到这里,我们的准备工作就做完了。完成这些后,系统的目录结构如下图所示:
     

     
    小结
          在这篇文章中,我们只是讲了一下这个系列文章要做什么,以及为案例做了一些准备工作。从下篇开始,我们将正式开始使用ASP.NET MVC完成这个案例。
  • 打印这篇文章
  • 与本文主题相关的文章
  • 返回首页