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

简介:

概述

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

准备数据访问

这里我们显示一个Post的列表DataContext和实体定义如下:
[Database(Name="Blog")]
public class BlogDataContext : DataContext
{
    public BlogDataContext()
        : base(@"Server=.\Sql2005;User Id=sa;Password=;Database=Blog")
    { 
        
    }
    public Table<Post> Posts
    {
        get
        {
            return this.GetTable<Post>();
        }
    }
}
Post实体:
[Table(Name="Posts")]
public class Post
{
    [Column(IsPrimaryKey=true,IsDbGenerated = true)]
    public int Id
    {
        get; set;
    }
    [Column]
    public string Title
    {
        get; set;
    }
    [Column]
    public string Author
    {
        get; set;
    }
    [Column]
    public DateTime PubDate
    {
        get; set;
    }
    [Column]
    public string Description
    {
        get; set;
    }
}
同时,我们定义一个BlogRepository类,用于读取Post数据,这样可以使得Controller中代码更加优雅,不再涉及数据访问:
public class BlogRepository
{
    public List<Post> GetAll()
    {
        BlogDataContext db = new BlogDataContext();
        IEnumerable<Post> posts = from p in db.Posts
                    orderby p.PubDate
                    select p;
        return posts.ToList<Post>();
    }
}

定义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>
在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(MvcRouteHandler)
                });
}
完成后,运行可以看到,使用行内代码和ListView控件的效果是一样的
 
 

结束语

在文章结束时,顺便说一下,好多朋友都问为什么有了WebForm,还要再出一个ASP.NET MVC Framework,对于这个问题,建议大家阅读一下这篇文章 What's Ailing ASP.NET Web Forms

示例代码下载:/Files/Terrylee/MVCDemo02.rar











本文转自lihuijun51CTO博客,原文链接:http://blog.51cto.com/terrylee/67776 ,如需转载请自行联系原作者





相关文章
|
2月前
使用的是.NET Framework 4.0,并且需要使用SMTP协议发送电子邮件
使用的是.NET Framework 4.0,并且需要使用SMTP协议发送电子邮件
57 1
|
2月前
|
开发框架 缓存 监控
NET Framework 到 .NET 5/6 的迁移是重大的升级
本文详细介绍了从 .NET Framework 4.8 迁移到 .NET 5/6 的过程,通过具体案例分析了迁移策略与最佳实践,包括技术栈评估、代码迁移、依赖项更新及数据库访问层的调整,强调了分阶段迁移、保持代码可维护性及性能监控的重要性。
62 3
|
2月前
|
机器学习/深度学习 编解码 算法
【小样本图像分割-4】nnU-Net: Self-adapting Framework for U-Net-Based Medical Image Segmentation
《nnU-Net: 自适应框架用于基于U-Net的医学图像分割》是一篇2018年的论文,发表在Nature上。该研究提出了一种自适应的医学图像分割框架nnU-Net,能够自动调整模型的超参数以适应不同的数据集。通过2D和3D U-Net及级联U-Net的组合,nnU-Net在10个医学分割数据集上取得了卓越的性能,无需手动调整。该方法强调数据增强、预处理和训练策略等技巧,为医学图像分割提供了一个强大的解决方案。
103 0
【小样本图像分割-4】nnU-Net: Self-adapting Framework for U-Net-Based Medical Image Segmentation
winform .net6 和 framework 的图表控件,为啥项目中不存在chart控件,该如何解决?
本文讨论了在基于.NET 6和.NET Framework的WinForms项目中添加图表控件的不同方法。由于.NET 6的WinForms项目默认不包含Chart控件,可以通过NuGet包管理器安装如ScottPlot等图表插件。而对于基于.NET Framework的WinForms项目,Chart控件是默认存在的,也可以通过NuGet安装额外的图表插件,例如LiveCharts。文中提供了通过NuGet添加图表控件的步骤和截图说明。
winform .net6 和 framework 的图表控件,为啥项目中不存在chart控件,该如何解决?
|
2月前
|
前端开发 Java 数据库
springBoot:template engine&自定义一个mvc&后端给前端传数据&增删改查 (三)
本文介绍了如何自定义一个 MVC 框架,包括后端向前端传递数据、前后端代理配置、实现增删改查功能以及分页查询。详细展示了代码示例,从配置文件到控制器、服务层和数据访问层的实现,帮助开发者快速理解和应用。
|
3月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
51 7
|
4月前
|
开发框架 缓存 前端开发
实战.NET Framework 迁移到 .NET 5/6
从.NET Framework 迁移到.NET 5/6 是一次重要的技术革新,涵盖开发环境与应用架构的全面升级。本文通过具体案例详细解析迁移流程,包括评估现有应用、利用.NET Portability Analyzer 工具识别可移植代码、创建新项目、逐步迁移代码及处理依赖项更新等关键步骤。特别关注命名空间调整、JSON 序列化工具更换及数据库访问层重构等内容,旨在帮助开发者掌握最佳实践,确保迁移过程平稳高效,同时提升应用性能与可维护性。
157 2
|
4月前
|
开发框架 JSON 监控
实战指南:从 .NET Framework 迁移到 .NET 5/6 的策略与最佳实践
【8月更文挑战第28天】从 .NET Framework 迁移到 .NET 5/6 是一次重要的技术升级,涉及开发环境与应用架构的改进。本文通过具体案例分析,介绍迁移策略与最佳实践,帮助开发者顺利完成转变。
95 1
|
3月前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
82 0
|
4月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
60 0

相关实验场景

更多