Asp.Net教程,WinForm教程,Asp.Net MVC,vs2008教程,vs2010教程,Silverlight技术,源码下载,Asp.Net视频教程
全站热门标签
vs2010 Silverlight 存储过程 水晶报表 ADO.NET JavaScript LINQ AjaxPro DataGridView 面向对象 Extjs GridView XML DevExpress HTML教程 Oracle jQuery 分页 GDI+ Visual C++2010 MySQL Office2010 WPF MVC Dojo WCF4.0 VB.NET Sql2005 textbox cookie WCF WinForm Discuz!NT SQL经典语句 T-SQL checkbox ASPxGridView F# asp.net SQL VS2008新特性 DropDownList Access TreeView Ajax VS2008 页面执行时间 Flex 字符串 回调 VB2005 DataSet C#时间 ASP.NET性能优化 用户在线检测 动画
当前位置: 主页 > Mvc技术 >

ASP.NET MVC Framework体验(2):显示列表数据(2)

时间:2010-06-30 20:43来源:未知 作者:admin 点击:

定义Controller

  这里的Controller定义就非常简单了,获取所有Post数据,然后把数据传给视图

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方法。

<h3>1.使用行内代码</h3>
  <%=Html.ActionLink("Home", new { action="Index"})%> |
  <div>
    <%fo reach (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>
  在HTML代码中编写时VS2008同样提供了很好的智能提示功能:


2.使用服务器控件ListView,编写代码如下:
<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去做。
public partial class Views_Blog_Index : ViewPage<List<Post>>
{
  protected void Page_Load(object sender, EventArgs e)
  {
    this.ListView1.DataSource = ViewData;
    this.ListView1.DataBind();
  }
}设置路径选择
  同样我们需要进行路径选择的设置
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(Mvc
this.ListView1.DataBind(); 
 }设置路径选择
  同样我们需要进行路径选择的设置
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(Mvc RouteHandler)
        });
}

  完成后,运行可以看到,使用行内代码和ListView控件的效果是一样的


 

 

 

(责任编辑:admin)
Tags:ASP.NET MVC MVC asp.net
责任编辑:admin
返回顶部
------分隔线----------------------------
推荐内容
骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价 骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价