asp.net mvc 显示列表数据

概述

ASP.NET WebForm下,显示列表数据,经常会使用服务器控件GridView、DataList等。在ASP.NET MVC Framework中,我们有两种方式进行显示数据,一是使用行内代码,即通过循环视图数据使用<%=%>标记进行呈现;二是使用服务器控件,同样可以把视图数据绑定在服务器控件,如ASP.NET 3.5中的新控件ListView。

定义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>
        <%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,编写代码如下:
<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(MvcRouteHandler)
                });
}



  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值