C# 中遍历树 ajax读取数据 递归算法实现数据树结构输出
数据表格字段为:id,Name,pID(父级ID)
js代码
<script language="javascript" type="text/javascript">
var htmlStr=new Array();
$(function(){
loadNode(0);
})
function loadNode(pid)
{
var vDtbl=_Default.GetChildren(pid).value;
if(vDtbl!=null)
{
for (var i = 0; i < vDtbl.Rows.length; i++) {
var NodeID = vDtbl.Rows[i]["id"];
var NodeName=vDtbl.Rows[i]["Name"];
var PID=vDtbl.Rows[i]["pID"];
htmlStr.push("<ul>");
htmlStr.push("<li id='"+NodeID+"'>");htmlStr.push(NodeName);htmlStr.push("</li>");
if(vDtbl.Rows.length!=0)// 判断该NodeID是否存在子集
{
loadNode(NodeID);
}
htmlStr.push("</ul>");
}// end for
var htmlcode="";
htmlcode=htmlStr.join("");
$("#loadNode").html(htmlcode);
}
}
</script>
服务器端C#代码
public DataTable GetChildren(int id)
{
[img]http://dl.iteye.com/upload/attachment/0066/5386/b847b4aa-7d65-33f0-aa03-2fe8337c943d.jpg[/img]
string strCon = "server=.;database=test;Integrated Security=sspi";
using (SqlConnection conn = new SqlConnection(strCon))
{
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "select id, Name,pID from tab_Tree where pID=" + id;
conn.Open();
cmd.CommandType = CommandType.Text;
SqlDataAdapter dbA = new SqlDataAdapter(cmd);
DataSet ds = new DataSet();
dbA.Fill(ds);
conn.Close();
return ds.Tables[0];
}
}
}
附件为我写的测试项目
- 大小: 5.9 KB
分享到:
相关推荐
Taihom原创,因为是原创才要分的请支持一下, 该存储过程可以在版本>=MSSQL2000下使用 但在MSSQL2000下,MPTT_NODEAction的resetnode操作不能使用,但不影响整个分类的主体应用 感谢ben一同测试。...
无限级分类----改进前序遍历树 二叉树 c# 无限极分类 前序遍历树
s2sh+freemarker+jquery+jquery-treeview 无限级树形菜单
JS无限级树形菜单3种
无限级树正向查找、反向查找例子【递归实现】 无限级树正向查找、反向查找例子【递归实现】 无限级树正向查找、反向查找例子【递归实现】
分析:通过这种数据库设计出的无限级,可以说读取的时候相当费劲,所以大部分的程序最多3-4级分类,这就足以满足需求,从而一次性读出所有的数据,再对得到数组或者对象进行递归。本身负荷还是没太大问题。但是如果...
c#实现无限级树菜单实例,使用递归方法,有需要的朋友看看。
主要介绍了json+jQuery实现的无限级树形菜单效果代码,涉及jquery针对json数据的遍历、读取及动态操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
首先这个包中对于分类这种具有树关系的数据是以树关系来描述的,查找,操作都是按照树的操作方式,显然比我们根据id和parent_id来遍历要方便,而且高效。就拿简单的来说。你查一个三级分类的顶级分类的所有后代分类...
方法一:用递归遍历数据,并将节点逐个添加到treeview中去。 1.先进行数据库连接和数据的读取,并将根节点先添加进treeview中,并利用递归getTreeView()实现数据的遍历和添加: 代码如下: protected void Page_...
其中“改进前序遍历树”数据结构,便于输出和查询,但是在移动分类和常规理解上有些复杂。 2.数据结构 <?php $list = array( array('id'=>1, 'fid'=>0, 'title' => '中国'), array('id'=>2, 'fid'=>1, '...
主要有两种方法:邻接列表模型和改进前序遍历树算法 在本文中,我们将探讨这两种保存层次数据的方法。我将举一个在线食品店树形图的例子。这个食品店通过类别、颜色和品种来组织食品。树形图如下: 本文包含了一些...
主要介绍了JS实现无限级网页折叠菜单(类似树形菜单)效果代码,涉及JavaScript基于鼠标事件实现针对页面元素结点的遍历及样式操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
接下来我会将自己的所见所闻和一些实用的经验和大家探讨一下:层级结构的数据保存在平面的数据库中基本上有两种常用设计方法: * 毗邻目录模式(adjacency list model) * 预排序遍历树算法(modified preorder tree