欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

DevExpress實(shí)現(xiàn)TreeList向上遞歸獲取公共父節(jié)點(diǎn)的方法

 更新時(shí)間:2014年08月06日 17:14:44   投稿:shichen2014  
這篇文章主要介紹了DevExpress實(shí)現(xiàn)TreeList向上遞歸獲取公共父節(jié)點(diǎn)的方法,需要的朋友可以參考下

有時(shí)候在進(jìn)行C#項(xiàng)目開(kāi)發(fā)中,需要獲取到公共節(jié)點(diǎn),如下圖所示:

譬如,當(dāng)點(diǎn)擊“Test103-2”節(jié)點(diǎn),其類(lèi)型是“燈”類(lèi)型,那怎么獲取到“中心區(qū)域”這個(gè)類(lèi)型是“地域”的公共節(jié)點(diǎn)?對(duì)此具體實(shí)現(xiàn)方法如下:

主要功能代碼如下:

/// <summary>
/// 向上遞歸,獲取符合條件的父節(jié)點(diǎn)
/// </summary>
/// <param name="node">需要向上遞歸的節(jié)點(diǎn)</param>
/// <param name="conditionHanlder">判斷條件【委托】</param>
/// <returns>符合條件的節(jié)點(diǎn)【TreeListNode】</returns>
public static TreeListNode GetParentNode(this TreeListNode node, Predicate<TreeListNode> conditionHanlder)
{
  TreeListNode _parentNode = node.ParentNode;//獲取上一級(jí)父節(jié)點(diǎn)
  TreeListNode _conditonNode = null;
  if (_parentNode != null)
  {
 if (conditionHanlder(_parentNode))//判斷上一級(jí)父節(jié)點(diǎn)是否符合要求
 {
   _conditonNode = _parentNode;
 }
 if (_conditonNode == null)//若沒(méi)有找到符合要求的節(jié)點(diǎn),遞歸繼續(xù)
   _conditonNode = GetParentNode(_parentNode, conditionHanlder);
  }
  return _conditonNode;
}
/// <summary>
/// 向上遞歸節(jié)點(diǎn)
/// </summary>
/// <param name="node">需要向上遞歸的節(jié)點(diǎn)</param>
/// <param name="conditionHanlder">委托,返回fasle跳出遞歸;返回true繼續(xù)遞歸;</param>
public static void UpwardRecursiveNode(this TreeListNode node, Predicate<TreeListNode> conditionHanlder)
{
  TreeListNode _parentNode = node.ParentNode;
  if (_parentNode != null)
  {
 if (conditionHanlder(_parentNode))
 {
   UpwardRecursiveNode(_parentNode, conditionHanlder);
 }
  }
}
/// <summary>
/// 向上遞歸,獲取符合條件的節(jié)點(diǎn)的公共父節(jié)點(diǎn)
/// </summary>
/// <param name="node">操作節(jié)點(diǎn)</param>
/// <param name="checkHanlder">委托</param>
/// <returns>符合條件的節(jié)點(diǎn)</returns>
public static TreeListNode 
GetPublicParentNode

(this TreeListNode node, Predicate<TreeListNode> checkHanlder)
{
  TreeListNode _publicPNode = null;
  TreeListNode _findNode = node.GetParentNode(checkHanlder);//先獲取到條件判斷的自身父節(jié)點(diǎn)
  if (_findNode != null)
  {
 //開(kāi)始向上遞歸
 UpwardRecursiveNode(_findNode, n =>
 {
   TreeListNode _curpublicNode = n.ParentNode;//獲取當(dāng)前向上遞歸的父節(jié)點(diǎn)
   if (_curpublicNode != null)
   {
 if (_curpublicNode.Nodes.Count > 1)//若有多個(gè)子節(jié)點(diǎn),則是公共父節(jié)點(diǎn)
 {
   _publicPNode = _curpublicNode;
   return false;//跳出遞歸
 }
   }
   return true;//繼續(xù)遞歸
 });
  }
  return _publicPNode;
}

希望本文所述示例對(duì)大家進(jìn)行類(lèi)似的C#項(xiàng)目開(kāi)發(fā)能有所幫助!

相關(guān)文章

最新評(píng)論