treeview选中子节点添加_节点在TreeView中无限添加,无刷新实现父节点选中,子节点同时选中...

这篇博客介绍了如何在Web页面上利用C#和数据库实现TreeView无限级添加子节点,并通过JavaScript实现无刷新的父子节点选中同步。博主通过创建SQL Server数据库表tbtree,然后在VS2005中使用ASP.NET创建Tree.aspx页面,展示了从数据库读取数据生成树形结构,并添加了JavaScript函数getcheck()以实现节点选中状态的同步更新。
摘要由CSDN通过智能技术生成

最近的一个项目要用到树形结构,所以找了很多关于树形结构的资料,感觉有着各种各样的问题。

现在把找到的比较实用的且比较简单和大家分享一下。

项目是在web页面下,通过数据库中表tbtree中的内容来实现树形结构的无限添加。

开发环境是vs2005,数据库是SQL SERVER2005

先在数据库test中创建表tbtree并插入数据

create table tbtree

(

ID int primary key,

Name nvarchar(50),

ParentID int

)

insert into tbtree(ID,Name,ParentId)values(1,'A',0);

insert into tbtree(ID,Name,ParentId)values(2,'B',0);

insert into tbtree(ID,Name,ParentId)values(3,'C',0);

insert into tbtree(ID,Name,ParentId)values(4,'A1',1);

insert into tbtree(ID,Name,ParentId)values(5,'B1',2);

insert into tbtree(ID,Name,ParentId)values(6,'C1',3);

insert into tbtree(ID,Name,ParentId)values(7,'A11',4);

insert into tbtree(ID,Name,ParentId)values(8,'A12',4);

insert into tbtree(ID,Name,ParentId)values(9,'A13',4);

insert into tbtree(ID,Name,ParentId)values(10,'B11',5);

insert into tbtree(ID,Name,ParentId)values(11,'B12',5);

insert into tbtree(ID,Name,ParentId)values(12,'B13',5);

insert into tbtree(ID,Name,ParentId)values(13,'C11',6);

insert into tbtree(ID,Name,ParentId)values(14,'C12',6);

insert into tbtree(ID,Name,ParentId)values(15,'C13',6);

insert into tbtree(ID,Name,ParentId)values(16,'A111',7);

insert into tbtree(ID,Name,ParentId)values(17,'A112',7);

insert into tbtree(ID,Name,ParentId)values(18,'A113',7);

insert into tbtree(ID,Name,ParentId)values(19,'A1111',16);

这样表就有了,可以进行调用了

在vs2005中添加一个新项Tree.aspx

代码如下(其中还用到javascript来实现无刷新的选中父节点,子节点同时选中)

无标题页

function getcheck()

{

var o = window.event.srcElement;

if (o.tagName == "INPUT" && o.type == "checkbox") //点击treeview的checkbox是触发

{

var d=o.id;//获得当前checkbox的id;

var e= d.replace("CheckBox","Nodes");//通过查看脚本信息,获得包含所有子节点div的id

var div= window.document.getElementById(e);//获得div对象

if(div!=null) //如果不为空则表示,存在子节点

{

var check=div.getElementsByTagName("INPUT");//获得div中所有的已input开始的标记

for(i=0;i

{

if(check[i].type=="checkbox") //如果是checkbox

{

check[i].checked=o.checked;//字节点的状态和父节点的状态相同,即达到全选

}

}

}

else //点子节点的时候,使父节点的状态改变,即不为全选

{

//处理父节点

var divid=o.parentElement.parentElement.parentElement.parentElement.parentElement; //子节点所在的div

var id= divid.id.replace("Nodes","CheckBox"); //获得根节点的id

var checkbox=divid.getElementsByTagName("INPUT"); //获取所有子节点数

var s=0;

for(i=0;i

{

if(checkbox[i].checked) //判断有多少子节点被选中

{

s++;

}

}

if(s==checkbox.length) //如果全部选中 或者 选择的是另外一个根节点的子节点 ,

{                               //    则开始的根节点的状态仍然为选中状态

window.document.getElementById(id).checked=true;

}

else

{                               //否则为没选中状态

window.document.getElementById(id).checked=false;

}

}

}

}

后台Tree.aspx.cs代码如下

using System;

using System.Data;

using System.Configuration;

using System.Collections;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;

using System.Data.SqlClient;

public partial class Tree : System.Web.UI.Page

{

protected void Page_Load(object sender, EventArgs e)

{

if (!IsPostBack)

{

bindtree();

TreeView1.Attributes.Add("onclick", "getcheck()");

}

}

void bindtree()

{

// 定义数据库连接

SqlConnection CN = new SqlConnection();

try

{

//初始化连接字符串

CN.ConnectionString = "database=test;server=.;user id=sa;Password=sa;";

CN.Open();

SqlDataAdapter adp = new SqlDataAdapter("select * from tbtree", CN);

DataSet ds = new DataSet();

adp.Fill(ds);

this.ViewState["ds"] = ds;

}

catch (Exception ex)

{

//Session["Error"] = ex.ToString();

//Response.Redirect("error.aspx");      //?跳转程序的公共错误处理页面

}

finally

{

CN.Close();

}

//调用递归函数,完成树形结构的生成

AddTree(0, (TreeNode)null);

}

public void AddTree(int ParentID, TreeNode pNode)

{

DataSet ds = (DataSet)this.ViewState["ds"];

DataView dvTree = new DataView(ds.Tables[0]);

//过滤ParentID,得到当前的所有子节点

dvTree.RowFilter = "ParentID = " + ParentID;

foreach (DataRowView Row in dvTree)

{

TreeNode Node = new TreeNode();

if (pNode == null)

{    //添加根节点

Node.Text = Row["Name"].ToString();

Node.Value = Row["ID"].ToString();

TreeView1.Nodes.Add(Node);

Node.Expanded = false;

AddTree(Int32.Parse(Row["ID"].ToString()), Node);    //再次递归

}

else

{  //?添加当前节点的子节点

Node.Text = Row["Name"].ToString();

Node.Value = Row["ID"].ToString();

pNode.ChildNodes.Add(Node);

Node.Expanded = false;

AddTree(Int32.Parse(Row["ID"].ToString()), Node);    //再次递归

}

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值