寒假中接触了asp.net的开发,到现在一直没有总结,很多好的方法也没来的及分享,现在也忘得差不多了,真的是个很大的损失。以后想起来了再和大家分享吧。
很多时候会看到,使用Treeview的时候展开这个节点,到另外一个页面的时候Treeview的状态又恢复了,下面就是从网上找的解决方法。不过存在一些问题,现在修正了。
using System;
using System.Data;
using System.Configuration;
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;
using System.Collections.Generic;
/// <summary>
///TreeViewState 的摘要说明
/// </summary>
public class TreeViewState
{
public void SaveTreeView(TreeView treeView, string key)
{
List<bool?> list = new List<bool?>();
SaveTreeViewExpandedState(treeView.Nodes, list);
HttpContext.Current.Session[key + treeView.ID] = list;
}
private void SaveTreeViewExpandedState(TreeNodeCollection nodes, List<bool?> list)
{
foreach (TreeNode node in nodes)
{
list.Add(node.Expanded);
if (node.ChildNodes.Count > 0)
{
SaveTreeViewExpandedState(node.ChildNodes, list);
}
}
}
private int RestoreTreeViewIndex;
public void RestoreTreeView(TreeView treeView, string key)
{
RestoreTreeViewIndex = 0;
RestoreTreeViewExpandedState(treeView.Nodes,
(List<bool?>)HttpContext.Current.Session[key + treeView.ID] ?? new List<bool?>());
}
private void RestoreTreeViewExpandedState(TreeNodeCollection nodes, List<bool?> list)
{
foreach (TreeNode node in nodes)
{
if (RestoreTreeViewIndex >= list.Count) return;
node.Expanded = list[RestoreTreeViewIndex++];
if (node.ChildNodes.Count > 0)
{
RestoreTreeViewExpandedState(node.ChildNodes, list);
}
}
}
}
在页面代码,TreeView的控件里事件里写:
//刷新时,页面还原为原来的信息
protected void TreeView1_Load(object sender, EventArgs e)
{
new TreeViewState().RestoreTreeView(TreeView1, this.GetType().ToString());
}
//点击展开和收缩的时候 保存节点的信息
protected void TreeView1_TreeNodeExpanded(object sender, TreeNodeEventArgs e)
{
new TreeViewState().SaveTreeView(TreeView1, this.GetType().ToString());
}
protected void TreeView1_TreeNodeCollapsed(object sender, TreeNodeEventArgs e)
{
new TreeViewState().SaveTreeView(TreeView1, this.GetType().ToString());
}