将简单的ASP.NET WebForm转换为MVC

时间:2011-09-14 10:10:20

标签: asp.net-mvc grid repeater webforms

我有简单的asp.net页面:

using System;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;

public partial class _Default : System.Web.UI.Page 
{
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            rptTable.DataSource = GetDataFromDB();
            rptTable.DataBind();
        }
    }

    private DataTable GetDataFromDB()
    {
        DataTable table = new DataTable();
        table.Columns.Add("Id", typeof(int));
        table.Columns.Add("Name", typeof(string));

        table.Rows.Add(1, "HDD");
        table.Rows.Add(2, "Video");
        table.Rows.Add(3, "RAM");

        return table;
    }

    protected void rptTable_ItemCommand(object source, RepeaterCommandEventArgs e)
    {
        TextBox tbName = (TextBox)e.Item.FindControl("tbName");
        int id = Convert.ToInt32(e.CommandArgument);
        string name = tbName.Text;

        //Category.Save(int id, string name)
        //Rebuild Repeater
    }

}

和aspx代码:

<%@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" EnableEventValidation="false" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <table>
        <asp:Repeater ID="rptTable" runat="server" OnItemCommand="rptTable_ItemCommand">
            <ItemTemplate>
                <tr>
                    <td>
                        <%#Eval("id")%>
                    </td>
                    <td>
                        <asp:TextBox ID="tbName" runat="server" Text='<%#Eval("Name")%>'></asp:TextBox>
                    </td>
                    <td>
                        <asp:Button ID="btnSave" runat="server" Text="Save" CommandArgument='<%#Eval("id")%>' />
                    </td>
                </tr>
            </ItemTemplate>
        </asp:Repeater>
        </table>
    </div>
    </form>
</body>
</html>

它的工作方式类似于简单的网格,您可以直接在网格中编辑数据。

如何在MVC中实现相同的逻辑? 谢谢!

1 个答案:

答案 0 :(得分:1)

要在MVC应用程序中复制asp:Repeater功能,通常会使用带有文本框的foreach循环绑定到模型属性。

但是,如果你真的想要,你可以在MVC应用程序中包含一个asp:repeater控件,但如果它依赖于回发,它就不会像你期望的那样工作。

如果它是一个简单的只读控件,您可以在视图中添加以下内容:

<scipt runat="server">
    protected void Page_Load(object sender, EventArgs e) {
        rptTable.DataSource = ViewData["yourViewDataList"];
        rptTable.DataBind();
    }
</script>

这假设你在ViewData中有一些可以数据绑定的东西,所以要做到这一点,你需要创建一个控制器方法来构建你的DataTable,就像你在'GetDataFromDB()'

我不会进入完整的实现,但是在高级别,这就是你如何在MVC中使用控件。