支持树型的GridView
实现思路: 继承自Gridview,处理gridview的数据源,使其在帮定时,就已经按照树型菜单顺序排列好,那样只需在帮定处理其图片是javascript脚本就可以了
。
源代码下载:https://files.cnblogs.com/wschacker/TreeListView.rar
效果图:
data:image/s3,"s3://crabby-images/cb5aa/cb5aa465d3340d994969f756054d60f07381fdbb" alt=""
代码:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
Code
using System;
using System.Data;
using System.Collections;
using System.Collections.Specialized;
using System.Collections.Generic;
using System.ComponentModel;
using System.Text;
using System.Web;
using System.IO;
using System.Drawing;
using System.Drawing.Design;
using System.Reflection;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
[ToolboxData("<{0}:TreeListView runat=server></{0}:TreeListView>"), DefaultProperty("Text")]
public class TreeListView : GridView, IPostBackDataHandler
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
{
public TreeListView()
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
base.AllowPaging = false;
base.AllowSorting = false;
base.AutoGenerateColumns = false;
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
Tree的属性设置#region Tree的属性设置
private int _nodeColumnIndex;
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 显示树型的列 Index
/// </summary>
public int NodeColumnIndex
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
get
{ return this._nodeColumnIndex; }
set
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
_nodeColumnIndex = value;
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
private string _columnKey;
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// Key字段
/// </summary>
public string ColumnKey
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
get
{ return _columnKey; }
set
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
_columnKey = value;
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
private string _parentKey;
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 指向父节点的字段
/// </summary>
public string ParentKey
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
set
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
_parentKey = value;
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
private string _sortKey;
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 排序字段
/// </summary>
public string SortKey
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
set
{ _sortKey = value; }
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
private object _rootNodeFlag;
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 根节点的标记 这里采用 ParentKey为什么字符
/// </summary>
public object RootNodeFlag
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
set
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
_rootNodeFlag = value;
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
private static string _treeImageFolder = "/Images/Tree/";
public static string TreeImageFolder
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
get
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return _treeImageFolder;
}
set
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
_treeImageFolder = value;
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
private int _expendDepth = 0;
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 展开的深度
/// </summary>
public int ExpendDepth
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
get
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return _expendDepth;
}
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
set
{ _expendDepth = value; }
}
#endregion
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public override object DataSource
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
get
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return base.DataSource;
}
set
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
DataTable dtSource = new DataTable();
if (value is DataSet && ((DataSet)value).Tables.Count > 0)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
DataSet ds = value as DataSet;
dtSource = OrderData(ds.Tables[0]);
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
throw new Exception("DataSource is not DataSet!");
}
base.DataSource = dtSource;
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
DataTable OrderData(DataTable dtSource)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
DataTable dtResult = dtSource.Clone();
dtResult.Columns.Add("TreeListView$Row$Depth", typeof(int));
dtResult.Columns.Add("TreeListView$Row$IsLeaf", typeof(bool));
dtResult.Columns.Add("TreeListView$Row$IsBottom", typeof(bool));
dtResult.Columns.Add("TreeListView$Row$ParentRow", typeof(DataRow));
dtResult.Columns.Add("TreeList$ViewRow$ClientID", typeof(string));
RecursionOrderData(dtSource, dtResult, _rootNodeFlag, -1, null);
return dtResult;
}
string FormatToRowFilter(object val)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
Type type = val.GetType();
if (type == typeof(string))
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return string.Format("'{0}'", val.ToString().Replace("'", "''"));
}
else if (type == typeof(Guid))
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return string.Format("'{0}'", val);
}
else if (type.IsValueType)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return val.ToString();
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return string.Format("'{0}'", val.ToString().Replace("'", "''"));
}
}
bool RecursionOrderData(DataTable dtSource, DataTable dtResult, object parentID, int depth, DataRow parentDatarow)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
DataView dv = new DataView(dtSource);
dv.RowFilter = string.Format("{0}={1}", _parentKey, FormatToRowFilter(parentID));
dv.Sort = _sortKey;
DataRow dr = null;
depth++;
for (int i = 0; i < dv.Count; i++)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
dr = dtResult.NewRow();
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
for (int j = 0; j < dv[i].Row.ItemArray.Length; j++)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
dr[j] = dv[i][j];
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
if (i == dv.Count - 1) //isBottom
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
dr["TreeListView$Row$IsBottom"] = true;
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
dr["TreeListView$Row$IsBottom"] = false;
}
dr["TreeListView$Row$Depth"] = depth;
dr["TreeListView$Row$ParentRow"] = parentDatarow;
if (depth == 0)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
dr["TreeList$ViewRow$ClientID"] = Guid.NewGuid().ToString();
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
dr["TreeList$ViewRow$ClientID"] = parentDatarow["TreeList$ViewRow$ClientID"].ToString() + "/" + Guid.NewGuid().ToString();
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
dtResult.Rows.Add(dr);
dr["TreeListView$Row$IsLeaf"] = !RecursionOrderData(dtSource, dtResult, dv[i][_columnKey], depth, dr);
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
return dv.Count > 0;
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public override bool AllowPaging
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
get
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return base.AllowPaging;
}
set
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
base.AllowPaging = false;
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public override bool AutoGenerateColumns
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
get
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return base.AutoGenerateColumns;
}
set
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
base.AutoGenerateColumns = false;
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
重载:CreateRow#region 重载:CreateRow
protected override GridViewRow CreateRow(int rowIndex, int dataSourceIndex, DataControlRowType rowType, DataControlRowState rowState)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return new TreeListViewRow(rowIndex, dataSourceIndex, rowType, rowState);
}
#endregion
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
重写:Rows#region 重写:Rows
private TreeListViewRowCollection _rowsCollection;
[Browsable(false)]
public new TreeListViewRowCollection Rows
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
get
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
ArrayList _rowsArray = new ArrayList();
for (int i = 0; i < base.Rows.Count; i++)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
_rowsArray.Add((TreeListViewRow)base.Rows[i]);
}
this._rowsCollection = new TreeListViewRowCollection(_rowsArray);
return this._rowsCollection;
}
}
#endregion
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
重载:OnInit#region 重载:OnInit
protected override void OnInit(EventArgs e)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
base.OnInit(e);
Page.RegisterRequiresPostBack(this);
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
if (!Page.ClientScript.IsClientScriptIncludeRegistered("JS_TreeListView"))
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
this.Page.ClientScript.RegisterClientScriptInclude(this.GetType(), "JS_TreeListView", Page.ClientScript.GetWebResourceUrl(this.GetType(), "GoldMantis.Web.UI.Resource.TreeListView.JS_TreeListView.js"));
}
}
#endregion
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
IPostBackDataHandler Members#region IPostBackDataHandler Members
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public bool LoadPostData(string postDataKey, NameValueCollection postCollection)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return false;
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public void RaisePostDataChangedEvent()
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
#endregion
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
方法:RenderCheckBoxExField#region 方法:RenderCheckBoxExField
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 处理CheckBoxExField类型的列
/// </summary>
private void RenderCheckBoxExField()
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (!this.ShowHeader && !this.ShowFooter)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return;
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
foreach (DataControlField field in Columns)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (field is CheckBoxExField)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
int checkBoxExFieldIndex = Columns.IndexOf(field) + this.GetAutoGenerateButtonCount();
foreach (GridViewRow row in Rows)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (row.RowType == DataControlRowType.Header)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
row.Cells[checkBoxExFieldIndex].Controls.Clear();
}
if (row.RowType == DataControlRowType.DataRow)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
row.Cells[checkBoxExFieldIndex].Controls[0].ID = "cbChoose";
((CheckBox)row.Cells[checkBoxExFieldIndex].Controls[0]).Attributes.Add("onclick", "ChooseTree(this);");
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
注册脚本#region 注册脚本
string script = @"
var modifyId = """" ;
var choosedId = """";
var choosedIndex;
function ChooseTree(obj)
{
var cTrId = obj.parentElement.parentElement.parentElement.id;
var treeTable = document.getElementById("""+this.ClientID+@""");
for( var i = 0; i < treeTable.rows.length; i++ )
{
if( treeTable.rows[i].id.indexOf(cTrId) != -1 && treeTable.rows[i].id != cTrId )
{
document.getElementById(treeTable.rows[i].id+""_cbChoose"").checked = obj.checked;
}
}
choosedId = """";
choosedIndex = new Array();
for( var i = 1; i < treeTable.rows.length; i++ )
{
if( document.getElementById(treeTable.rows[i].id+""_cbChoose"").checked )
{
choosedId += treeTable.rows[i].id.substring(treeTable.rows[i].id.lastIndexOf(""/"")+1) + "","";
choosedIndex.push(i);
}
}
choosedId = choosedId.substring(0,choosedId.length-1);
}";
if (!Page.ClientScript.IsStartupScriptRegistered("TreeListView_CheckBoxExField"))
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
Page.ClientScript.RegisterStartupScript(GetType(), "TreeListView_CheckBoxExField", script, true);
}
#endregion
}
}
}
data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
方法:GetAutoGenerateButtonCount#region 方法:GetAutoGenerateButtonCount
private int GetAutoGenerateButtonCount()
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
int num = 0;
if (this.AutoGenerateDeleteButton || this.AutoGenerateEditButton || this.AutoGenerateSelectButton)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
num = 1;
}
return num;
}
#endregion
#endregion
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
protected override void Render(HtmlTextWriter writer)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
RenderCheckBoxExField();
base.Render(writer);
}
}
public class TreeListViewRow : GridViewRow
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
{
public TreeListViewRow(int rowIndex, int dataItemIndex, DataControlRowType rowType, DataControlRowState rowState)
: base(rowIndex, dataItemIndex, rowType, rowState)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
}
protected override void OnPreRender(EventArgs e)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
base.OnPreRender(e);
if (this.RowType == DataControlRowType.DataRow)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (this.Parent.Parent is TreeListView)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
TreeListView treeListView = this.Parent.Parent as TreeListView;
DataRow dr = ((DataTable)treeListView.DataSource).Rows[this.DataItemIndex] as DataRow;
string str = GetTreeNodeImg(dr, Convert.ToBoolean(dr["TreeListView$Row$IsLeaf"]), Convert.ToBoolean(dr["TreeListView$Row$IsBottom"]));
this.Cells[treeListView.NodeColumnIndex].Text = str + this.Cells[treeListView.NodeColumnIndex].Text;
this.ID = dr["TreeList$ViewRow$ClientID"].ToString();
if (treeListView.ExpendDepth > 0)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
this.Style["display"] = treeListView.ExpendDepth >= Convert.ToInt32(dr["TreeListView$Row$Depth"]) ? "block" : "none";
}
}
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/d971a/d971a4cc90bc374b8da297f155149f2530d697e9" alt=""
获取Tree的图片#region 获取Tree的图片
string GetTreeNodeImg(DataRow dr, bool isLeaf, bool isBottom)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return GetTreeNodeOtherImg(dr) + GetTreeNodeLastImg(isLeaf, isBottom);
}
string GetTreeNodeOtherImg(DataRow dr)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (dr["TreeListView$Row$ParentRow"] != null&&!dr["TreeListView$Row$ParentRow"].Equals(DBNull.Value))
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
DataRow drParentRow = dr["TreeListView$Row$ParentRow"] as DataRow;
bool parentIsBottom = Convert.ToBoolean(drParentRow["TreeListView$Row$IsBottom"]);
if (parentIsBottom)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return GetTreeNodeOtherImg(drParentRow) + string.Format("<img src={0} align=absmiddle>", TreeListView.TreeImageFolder + "white.gif");
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return GetTreeNodeOtherImg(drParentRow) + string.Format("<img src={0} align=absmiddle>", TreeListView.TreeImageFolder + "i.gif");
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return string.Empty;
}
}
string GetTreeNodeLastImg(bool isLeaf, bool isBottom)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
//最后靠近的那个Image
string lastImg = string.Empty;
if (isLeaf)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (isBottom)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
lastImg = string.Format("<img src={0} align=absmiddle>", TreeListView.TreeImageFolder + "l.gif");
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
lastImg = string.Format("<img src={0} align=absmiddle>",TreeListView.TreeImageFolder + "t.gif");
}
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (isBottom)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
lastImg = string.Format("<img src={0} align=absmiddle onclick='ClickNode(this,true,\"
{1}\");' style=\"cursor: hand\">", TreeListView.TreeImageFolder + "lminus.gif", this.Parent.Parent.ClientID);
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
lastImg = string.Format("<img src={0} align=absmiddle onclick='ClickNode(this,true,\"
{1}\");' style=\"cursor: hand\">", TreeListView.TreeImageFolder + "tminus.gif", this.Parent.Parent.ClientID);
}
}
return lastImg;
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
}
#endregion
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
Js代码实现折叠效果
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
Code
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
var lExpend = "lminus.gif";
var lPinch = "lplus.gif";
var tExpend = "tminus.gif";
var tPinch = "tplus.gif";
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
function ClickNode(img,isBottom,tableId)
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
{
var imgId = img.src.substring(img.src.lastIndexOf("/")+1);
var url = img.src.substring(0,img.src.lastIndexOf("/")+1);
var oldTrId = img.parentElement.parentElement.id;
var newTrId = oldTrId.substring(oldTrId.indexOf("_")+1);
if( isBottom)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if( imgId == lExpend)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
img.src = url+ lPinch;
img.parentElement.id = lPinch;
PinchNode(newTrId,oldTrId,tableId);
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
img.src = url + lExpend;
img.parentElement.id = lExpend;
ExpendNode(newTrId,oldTrId,tableId);
}
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if( imgId == tExpend )
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
img.src = url+ tPinch;
img.parentElement.id = tPinch;
PinchNode(newTrId,oldTrId,tableId);
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
img.src = url + tExpend;
img.parentElement.id = tExpend;
ExpendNode(newTrId,oldTrId,tableId);
}
}
}
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
function ExpendNode(newId,oldId,tableId)
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
{
var tree = document.getElementById(tableId);
for( var i = 0; i < tree.rows.length; i++ )
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if( tree.rows[i].id.indexOf(newId) != -1 && tree.rows[i].id != oldId )
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
var isExpend = true;
var pId = tree.rows[i].id;
while( pId != oldId)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
for( var j = 0; j < 2; j++ )
pId = pId.substring( 0,pId.lastIndexOf("/"));
var parent = document.getElementById(pId);
if( parent != null )
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
var tempId = parent.cells[2].id;
if( tempId == lExpend || tempId == tExpend || tempId == "")
;
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
isExpend = false;
break;
}
}
else
break;
}
if( isExpend )
tree.rows[i].style.display="block";
}
}
}
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
function PinchNode(newId,oldId,tableId)
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
{
var tree = document.getElementById(tableId);
for( var i = 0; i < tree.rows.length; i++ )
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if( tree.rows[i].id.indexOf(newId) != -1 && tree.rows[i].id != oldId)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
tree.rows[i].style.display = "none";
}
}
}