从GridView行获取对象

时间:2009-02-11 22:48:34

标签: asp.net gridview

基本上,我希望我的对象回来......

我有一个电子邮件对象。

public class Email{
    public string emailAddress;
    public bool primary;
    public int contactPoint;
    public int databasePrimaryKey;

    public Email(){}
}

在我的usercontrol中,我是一个电子邮件对象列表。

public List<Email> EmailCollection;

我将它绑定到我的usercontrol中的GridView。

if(this.EmailCollection.Count > 0){
    this.GridView1.DataSource = EmailCollection;
    this.GridView1.DataBind();
}

如果我可以稍后将GridView对象 out out ,那真的很棒。

我该怎么做?

我也将一些Email对象的属性绑定到GridView,并将它们放入项目模板中。

<Columns>

<asp:TemplateField HeaderText="Email Address">
    <ItemTemplate>
        <asp:TextBox ID="TextBox1" runat="server" Text=<%# Eval("EmailAddress") %> Width=250px />
    </ItemTemplate>
</asp:TemplateField>

<asp:TemplateField HeaderText="Primary">
    <ItemTemplate>
        <asp:CheckBox runat="server" Checked=<%# Eval("PrimaryEmail") %> />
    </ItemTemplate>
</asp:TemplateField>

<asp:TemplateField HeaderText="Contact Point">
    <ItemTemplate>
        <CRM:QualDropDown runat="server" Type=ContactPoint InitialValue=<%# Eval("ContactPoint") %> />
    </ItemTemplate>
</asp:TemplateField>

</Columns>

GridView甚至可以这样做吗?我需要自己动手吗?如果能为我做这件事真的很酷。


详细说明。

我将List集合保存到viewstate中。

我最终想要的是,控件中某处会有一个Save按钮,当事件触发时我想从GridView中的数据行创建一个Email对象,与我的对比原始列表集合。然后,如果有更改,那么我将更新数据库中的那一行。我在想如果我可以把一个List集合放到GridView中,那么也许我可以把它恢复原状。

也许我为我的Email对象创建了一个新的构造函数,它接受了DataRow?但是那时候会有很多复杂的问题......

4 个答案:

答案 0 :(得分:5)

ASP.NET Databinding就对象操作而言是一种单向操作。但是,DataSource属性将在整个响应中包含对EmailCollection的引用:

EmailCollection col = (EmailCollection)this.GridView1.DataSource;

但我觉得你真正想要的是一个控件,它根据用户输入操纵你的EmailCollection并在下一个请求中检索它。甚至连webforms都不能伪造那种开箱即用的状态。

答案 1 :(得分:3)

好吧,我最终循环浏览了我的List EmailCollection,它被保存到ViewState中。

因此,在页面中,单击一个Save按钮,当捕获事件时,我遍历我的List Collection并通过索引从GridView中获取行。

在GridViewRow上我必须使用GridView1.Rows [i] .Cells [j] .FindControl(“myControl1”)然后从中获取适当的值,无论是复选框,文本框还是下拉列表

我确实看到GridViewRow对象有一个DataItem属性,它包含我的Email对象,但它只在RowBound阶段可用。

不幸的是,当我以后需要扩展此电子邮件集合时,通过添加或删除列,它将需要几个步骤。

protected void SaveButton_OnClick(object sender, EventArgs e){
    for (int i = 0; i < this.EmailCollection.Count; i++)
    {
        Email email = this.EmailCollection[i];
        GridViewRow row = this.GridView1.Rows[i];

        string gv_emailAddress = ((TextBox)row.Cells[0].FindControl("EmailAddress")).Text;
        if (email.EmailAddress != gv_emailAddress)
        {
            email.EmailAddress = gv_emailAddress;
            email.Updated = true;
        }
        ...
    }
}

我仍然愿意接受更有效的解决方案。

答案 2 :(得分:0)

如果你想保持这样的对象最容易使用viewstate,虽然你将复制数据但是对于一个小对象它应该没问题。

ViewState.Add("EmailObj", Email);

EMail email = (Email)ViewState["EmailObj"];

答案 3 :(得分:0)

只是一个想法,基本上是你自己的但不是那么棘手:

将您用作数据源的列表存储在视图状态或会话中,并将gridview中的隐藏字段作为索引或与该行匹配的对象的键。

换句话说,gridview中的每一行“都知道”它所基于的列表中的哪个电子邮件对象。