基本上,我希望我的对象回来......
我有一个电子邮件对象。
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?但是那时候会有很多复杂的问题......
答案 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中的每一行“都知道”它所基于的列表中的哪个电子邮件对象。