我在自定义控件中有以下属性:
List<myClass> _items;
public List<myClass> Items{
get { return _items; }
set { _items= value; }
}
在我的代码隐藏中,我将项目添加到集合中,如...
myCustomControl.items.Add(new myClass());
但是,这些不会在回发中保留。允许自定义控件持久性的正确方法是什么?
我在自定义控件中有以下属性:
List<myClass> _items;
public List<myClass> Items{
get { return _items; }
set { _items= value; }
}
在我的代码隐藏中,我将项目添加到集合中,如...
myCustomControl.items.Add(new myClass());
但是,这些不会在回发中保留。允许自定义控件持久性的正确方法是什么?
哎呀!不要将 List<> 放入 ViewState!这将是巨大的!
如果将包含两个元素“abc”和“xyz”的 List<string> 添加到 ViewState 中,它将增加 312 个字节。
相反,如果您添加一个包含相同两个元素的 string[],它只会增长 24 个字节。
那只是字符串列表!您可以按照 Corey Downie 的建议将您的课程放在那里,但您的 ViewState 会迅速增长!
为了保持合理的大小,您必须努力将项目列表转换为字符串数组,然后再转换回来。
作为替代方案,考虑将您的对象放入 Session:这样您的对象将存储在服务器上,而不是被序列化为 ViewState 并发送到浏览器并返回。
克服泛型列表大小问题的一种方法是将其作为基本数组类型保存在 ViewState 中:
protected List<string> Items
{
get
{
if (ViewState["Items"] == null)
ViewState["Items"] = new string[0];
return new List<string>((string[])ViewState["Items"]);
}
set
{
ViewState["Items"] = value.ToArray();
}
}
如果您正在谈论在同一页面的回发中保留数据,那么您可以手动将项目添加到 ViewState 并在加载时检索它们。
我同意视图状态中的 List<> 存在问题,但它确实有效。请注意,设计上没有设置器。您需要对列表对象对象的引用,并且您的 get 方法可以在需要时新建一个列表。
protected List<myClass> Items
{
get
{
if (ViewState["myClass"] == null)
ViewState["myClass"] = new List<myClass>();
return (List<myClass>)ViewState["myClass"];
}
}
您可以将它们存储在控件视图状态中
public List<myClass> Items{
get { return this.ViewState["itemsKey"] }
set { this.ViewState["itemsKey"]= value; }
}