概述
ASP.NET WebForm下,显示列表数据,经常会使用服务器控件GridView、DataList等。在ASP.NET MVC Framework中,我们有两种方式进行显示数据,一是使用行内代码,即通过循环视图数据使用<%=%>标记进行呈现;二是使用服务器控件,同样可以把视图数据绑定在服务器控件,如ASP.NET 3.5中的新控件ListView。
定义Controller
这里的Controller定义就非常简单了,获取所有Post数据,然后把数据传给视图
[csharp] view plaincopy
- public class BlogController : Controller
- {
- [ControllerAction]
- public void Index()
- {
- // 获取所有post数据
- BlogRepository repository = new BlogRepository();
- List<Post> posts = repository.GetAll();
- // 转向视图Index,显示Post列表
- RenderView("Index", posts);
- }
- }
定义View
添加一个Index视图,并使其继承于ViewPage<List<Post>>。
1.使用行内代码显示,进行数据的循环并使用ViewPage提供的HtmlHelper方法。
[html] view plaincopy
- <h3>1.使用行内代码</h3>
- <%=Html.ActionLink("Home", new { action="Index"})%> |
- <div>
- <%foreach (Post post in ViewData)
- { %>
- <div class="postitem">
- <strong>Title</strong>:<%=Html.Encode(post.Title) %></br>
- <strong>Author</strong>:<%=Html.Encode(post.Author) %></br>
- <strong>PubDate</strong>:<%=Html.Encode(post.PubDate.ToShortDateString()) %></br>
- <strong>Content</strong>:<%=Html.Encode(post.Description) %></br>
- </div><br />
- <% } %>
- </div>
2.使用服务器控件ListView,编写代码如下:
[html] view plaincopy
- <h3>使用ListView控件</h3>
- <asp:ListView ID="ListView1" runat="server">
- <LayoutTemplate>
- <div>
- <asp:PlaceHolder ID="itemPlaceHolder" Runat="server"/>
- </div>
- </LayoutTemplate>
- <ItemTemplate>
- <div class="postitem">
- <strong>Title</strong>:<%# Eval("Title") %></</br>
- <strong>Author</strong>:<%# Eval("Author")%></br>
- <strong>PubDate</strong>:<%# Eval("PubDate")%></br>
- <strong>Content</strong>:<%# Eval("Description") %></br>
- </div><br />
- </ItemTemplate>
- </asp:ListView>
在后台代码中进行ListView的数据绑定,这里仅仅是对把视图数据绑定到了ListView上面,从数据库中获取数据交给Controller去做。
[csharp] view plaincopy
- public partial class Views_Blog_Index : ViewPage<List<Post>>
- {
- protected void Page_Load(object sender, EventArgs e)
- {
- this.ListView1.DataSource = ViewData;
- this.ListView1.DataBind();
- }
- }
设置路径选择
同样我们需要进行路径选择的设置
[csharp] view plaincopy
- void Application_Start(object sender, EventArgs e)
- {
- // Code that runs on application startup
- RouteTable.Routes.Add(
- new Route
- {
- Url = "[controller]/[action].mvc",
- Defaults = new { action = "Index" },
- RouteHandler = typeof(MvcRouteHandler)
- });
- }
时间: 2024-10-18 02:29:00