- 你所在位置:首页 〉VS.net〉ASP.net〉开发〉DynamicData for Asp.net Mvc留言本实例 上篇 准备工作及显示文章列表
- DynamicData for Asp.net Mvc留言本实例 上篇 准备工作及显示文章列表
- 作者:重典 文章来源:www.cnblogs.com 发布日期:2008-11-15 浏览次数:84
-
- 打印这篇文章
-
DynamicDataMVC出现也有一段时间了,一直没有正视它,今天抽一点时间了解了一下感觉还算不错。
本身下载时自带一个博客的例子,但例子略显复杂,不容易理清思路
附:本文初稿某兄入手先读,提出诸多疑问想必其它朋友可能也会有类似问题,故蓝字注明,当然大多朋友可以省去不看
下载及新建工程
下载地址:http://www.codeplex.com/aspnet/Release/ProjectReleases.aspx 选那个DynamicDataMVC.zip就行,如随版本变化,请大家举一反三。
本文环境为Visual Studio 2008/Sql Server 2005
1、建立一个Asp.net Mvc工程:DMvc
2、引用Microsoft.Web.DynamicData.Mvc.DLL,及系统组件System.ComponentModel.DataAnnotations和System.Web.DynamicData
3、在Web.config中的pages/namespaces添加一个add节点其namespace属性为Microsoft.Web.DynamicData.Mvc
4、system.web/compilation/assemblies中添加节点add 〈add assembly="System.Web.DynamicData, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/>
5.将DynamicDataMVC中Views/Shared/ 中的ValidationSummary.ascx EntityTemplates及FieldTemplates复制到我们新建的Mvc工程的Views/Shared文件夹
数据库准备工作
建立Articles表
打开Microsoft SQL Server Management Studio连接后对数据库点右键,新建数据库
生成Linq to Sql的dbml文件:
如果不会建,可以搜索关键字:Linq to SQL入门
这个DataContext叫做DMvcDataDataContext
为了查询方便,我们先向其中加些数据(不多写了,也就20条就够了)
INSERT INTO [Articles]([Title],[Body],[AddTime],[Author]) VALUES('文章1','内容1',getdate(),'重典') INSERT INTO [Articles]([Title],[Body],[AddTime],[Author]) VALUES('文章2','内容2',getdate(),'重典') INSERT INTO [Articles]([Title],[Body],[AddTime],[Author]) VALUES('文章3','内容3',getdate(),'重典')让网站运行起来,显示文章列表
先来个效果图(我美工就这么地了,大家谅解一下)
就是将文章列了出来,我们下面为了这个目标而努力
首先,也是很重要的,要先在Application_Start中添加我们要自动化的DataContext
protected void Application_Start() { RegisterRoutes(RouteTable.Routes); var model = new MetaModel(); model.RegisterContext(typeof(DMvc.Models.DMvcDataDataContext), new ContextConfiguration { ScaffoldAllTables = true }); }
如果您不知道Application_Start在哪里,可以百度一下:Global.asax文件的作用
我们建一个新的Controller:ArticleController来专门进行Article的CRUD(Create/Read/Update/Delete).
我们首先建一个叫List的Action.从数据库中读取数据放入ViewData.Model中
public class ArticleController : Controller { /// 〈summary> /// 文章列表 /// 〈/summary> /// 〈param name="p">当前页号〈/param> /// 〈param name="ps"> pagesize〈/param> /// 〈returns>〈/returns> public ActionResult List(int? p, int? ps) {// if (!p.HasValue) p = 1;//处理为空时的情况 if (!ps.HasValue) ps = 4;//默认一页4条 using (var db = new DMvcDataDataContext()) { var x = new PagedList〈Articles>(db.Articles, p.Value, ps.Value);//读取数据并自动分页 return View(x); } } }
这里我们用到了PagedList这个类来将db.Articles自动分页,它是DynamicData的一个辅助工具,用起来还算不错
我们再建立一个View页使之继承于PagedList〈Articles>
即:
public partial class List : ViewPage〈PagedList〈Articles>> { }
在view中我们写如下代码:
〈!--显示列表开始--> 〈%foreach (var a in ViewData.Model) { %> 〈fieldset> 〈legend> 〈% Html.RenderDynamicField(a, "Title"); %>〈/legend> 内容:〈%Html.RenderDynamicField(a, "Body"); %>〈br /> 发表日期:〈%Html.RenderDynamicField(a, "Addtime"); %> 作者:〈%Html.RenderDynamicField(a, "Author"); %> 〈/fieldset> 〈% } %> 〈!--显示列表结束--> 〈!--分页的按钮开始--> 分页按钮 〈% if (ViewData.Model.HasPreviousPage) { %> 〈%=Html.ActionLink("第一页", "List", new { p=1},null)%> 〈%=Html.ActionLink("上一页", "List", new { p = ViewData.Model.CurrentPage - 1 }, null)%> 〈% }else { %> 第一页 上一页 〈% } %> 当前:〈%= ViewData.Model.CurrentPage %> /共〈%= ViewData.Model.TotalPages%>页 〈% if (ViewData.Model.HasNextPage) { %> 〈%=Html.ActionLink("下一页", "List", new { p = ViewData.Model.CurrentPage + 1 }, null)%> 〈%=Html.ActionLink("最后页", "List", new { p = ViewData.Model.TotalPages }, null)%> 〈% }else { %> 下一页 最后页 〈% } %> 〈!--分页的按钮结束-->虽然有点乱,但是基本上分成数据显示和分页按钮两个部分最后访问/article/List?p=2就会看到前面图中的效果
- 打印这篇文章
- 与本文主题相关的文章
- 返回首页
