首页  ·  知识 ·  
Label
      编辑:  图片来源:网络
上次写了这篇文章后,马上发觉有个错误,即可能存在Node漏加的情况。因在添加节点时,只有一个循环,当添加节点时,可能父节点还没有添加,即找不到父亲了,这就引起漏加。
真对不起,没有慎重。不过俺平常就是很随便的,一件事没想成熟就去做,但发现错了,一定会订正的。如果你不喜欢我这样,就把文章扔在一边吧。

原来程序:
///
/// 重设商品分类的 TreeView
/// ResetSortView() 函数
///

#region ResetSortView()函数实现
private void ResetSortView()
{
trvSort.Nodes.Clear();
arrNode.Clear();

ExNode nd = new ExNode();
//
// 添加商品总类
//
Sort mySort = new Sort();
mySort.ID = 0;
mySort.Name = "商品总类";
mySort.ParentID = -1;
mySort.IsEnd =false;
mySort.Disable = false;
nd.Sort = mySort;
nd.ImageIndex = 0;
nd.SelectedImageIndex = 0;
trvSort.Nodes.Add(nd);
arrNode.Add(nd);
// 打开数据库
// 不好意思,我把数据库打开都定义类了,全包装在DBClass内
// 这样换成SQL SERVER就省力些
// DataSet这里也封装,为myDB.DBDataSet
// 懒得定数据库了,如果不熟悉数据库,快学习一下
string sql = "Select * From MerchandiseSort Order by MerchandiseSortID";
DBClass myDB = new DBClass();
myDB.DBOpen();
myDB.CreateAdapter(sql);
myDB.FillDataSet();
//
// 把数据记录逐一添加到树开上去
// 错误从这里开始
// --------------------------------------------------------------------------------------
for (int i = 1; i <= myDB.DBDataSet.Tables[0].Rows.Count; i++)
{
mySort.ID = (int)myDB.DBDataSet.Tables[0].Rows[i-1]["MerchandiseSortID"];
mySort.Name = myDB.DBDataSet.Tables[0].Rows[i-1]["Name"].ToString();
mySort.ParentID = (int)myDB.DBDataSet.Tables[0].Rows[i-1]["ParentID"];
mySort.IsEnd = (bool)myDB.DBDataSet.Tables[0].Rows[i-1]["IsEnd"];
mySort.Disable = (bool)myDB.DBDataSet.Tables[0].Rows[i-1]["Disable"];
AddNode(mySort);
}
// --------------------------------------------------------------------------------------
myDB.DBClose();
trvSort.ExpandAll();

}

该代码重写,即向TreeView中成功添加一后,从DataSet口中删去该节点记录,并进行新的一次循环,否则DataSet往下查找能添加的记录。程序如下:

修正后的添加节点的子程序:
///
/// 在treeView中增加Node,并把Node加入到数组,方便查询
///

private bool AddNode(Sort addSort)
{
bool Added = false;

ExNode parentNode = new ExNode(); // 要挂接的父结点
ExNode addNode = new ExNode(); // 本结点

addNode.Sort = addSort;

if (addNode.Sort.ParentID == 0)
{
trvSort.Nodes[0].Nodes.Add(addNode);
// 使标志设为找到
Added = true;
arrNode.Add(addNode);
addNode.IDPath = "root\\0";
}
else
{
foreach ( ExNode pNode in arrNode )
{
if ( pNode.Sort.ID == addSort.ParentID)
{
parentNode = pNode;
parentNode.Nodes.Add(addNode);
arrNode.Add(addNode);
addNode.IDPath = parentNode.IDPath + "\\" + addNode.Sort.ParentID.ToString();
// 使标志设为找到
Added = true;

break;
}
}
}

// 如果没有找到,返回False
if ( !Added ) return false;

if (addSort.IsEnd)
{
if (addSort.Disable)
{
addNode.ImageIndex = 4;
addNode.SelectedImageIndex = 4;
addNode.ForeColor = SystemColors.GrayText;
}
else
{
addNode.ImageIndex = 2;
addNode.SelectedImageIndex = 2;
addNode.ForeColor = SystemColors.WindowText;
}
}
else
{
if (addSort.Disable)
{
addNode.ImageIndex = 3;
addNode.SelectedImageIndex = 3;
addNode.ForeColor = SystemColors.GrayText;
}
else
{
addNode.ImageIndex = 1;
addNode.SelectedImageIndex = 1;
addNode.ForeColor = SystemColors.WindowText;
}
}

return true;
}

修正后的显示分类树程序:

///
/// 重设商品分类的 TreeView
///

public void ResetSortView()
{
trvSort.Nodes.Clear();
arrNode.Clear();

ExNode nd = new ExNode();
//
// 添加商品总类
//
Sort mySort = new Sort();
mySort.ID = 0;
mySort.Name = "商品总类";
mySort.ParentID = -1;
mySort.IsEnd =false;
mySort.Disable = false;
nd.Sort = mySort;
nd.ImageIndex = 0;
nd.SelectedImageIndex = 0;
trvSort.Nodes.Add(nd);
arrNode.Add(nd);
nd.IDPath = "root";

string sql = "SELECT * FROM MerchandiseSort ORDER BY MerchandiseSortID ASC";
DBClass myDB = new DBClass();
myDB.DBOpen();
myDB.CreateAdapter(sql);
myDB.FillDataSet();

//
// 以下修正后代码,用二重循环,真到DataSet中的记录全部添加为止
//
while ( myDB.DBDataSet.Tables[0].Rows.Count > 0 )
{
for (int i = 1; i <= myDB.DBDataSet.Tables[0].Rows.Count; i++)
{
mySort.ID = (int)myDB.DBDataSet.Tables[0].Rows[i-1]["MerchandiseSortID"];
mySort.Name = myDB.DBDataSet.Tables[0].Rows[i-1]["SortName"].ToString();
mySort.ParentID = (int)myDB.DBDataSet.Tables[0].Rows[i-1]["ParentID"];
mySort.IsEnd = (bool)myDB.DBDataSet.Tables[0].Rows[i-1]["IsEnd"];
mySort.Disable = (bool)myDB.DBDataSet.Tables[0].Rows[i-1]["Disable"];

// 如果添加成功,岀删除DataSet中相应记录,并进入新的循环
if ( AddNode(mySort) )
{
myDB.DBDataSet.Tables[0].Rows.RemoveAt(i - 1);
myDB.DBDataSet.Tables[0].AcceptChanges();
break;
}
}
}

myDB.DBClose();
trvSort.CollapseAll();
trvSort.Nodes[0].Expand();
}
本文作者:佚名 来源:http://www.5ivb.net
CIO之家 www.ciozj.com 微信公众号:imciow
   
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。
延伸阅读
也许感兴趣的
我们推荐的
主题最新
看看其它的
收藏至微信