asp TreeView控件的使用
相对于之前发过一个TreeView控件的使用方法
本次利用js操作,页面无刷新,性能提高
Css编码可能时我的模板页样式被继承下来,导致页面变乱,不需要的可以去掉
前台
<style>
.tn td {
height: 18px;
line-height: 18px;
display: flex;
} .tn tr {
display: flex;
} .tn a {
line-height: 18px;
color: black;
}
</style>
Css Code
<asp:TreeView ID="tv_roleaction" runat="server" ShowCheckBoxes="All" CssClass="tn" ShowLines="True" CollapseImageToolTip="折叠">
</asp:TreeView>
Html Code
var nodecheck = {
init: function () {
//配合asp treeview使用
//需在页面加载时设置 this.TreeView.Attributes.Add("onclick", "nodecheck.init()");
var element = event.srcElement;
if (element.tagName == "INPUT" && element.type == "checkbox") {
var checkedState = element.checked;
while (element.tagName != "TABLE") { //获取当前节点所在的table
element = element.parentElement;
}
this.SetChildChecked(element, checkedState);
this.SetParentChecked(element, checkedState);
}
},
SetChildChecked: function (table, checked) {
table = table.nextSibling;
if (table == null || !table.translate) //判断有没有子节点
return;
var childTables = table.getElementsByTagName("TABLE");//获取所有子节点所在的table
for (var tableIndex = 0; tableIndex < childTables.length; tableIndex++) {
this.SetNodeChecked(childTables[tableIndex], checked);
}
},
SetParentChecked: function (table, checked) {
if (table == null || table.rows[0].cells.length == 2) {
return;
}
var parentTable = table.parentElement.previousElementSibling;//获得父级table
if (parentTable == null || !parentTable.translate) //没有父节点就停止
return;
//判断父节点下有没有被选中的节点
node = parentTable.nextSibling;
var ifnochecked = true;
if (node == null || !node.translate) //判断有没有子节点 --没有子节点就停止
return;
var childTables = node.getElementsByTagName("TABLE");//获取所有子节点所在的table
for (var tableIndex = 0; tableIndex < childTables.length; tableIndex++) {
if (this.GetNodeChecked(childTables[tableIndex])) {
ifnochecked = false;
this.SetNodeChecked(parentTable, true);
break;
}
}
if (ifnochecked) {
this.SetNodeChecked(parentTable, false);
}
this.SetParentChecked(parentTable, checked);
},
SetNodeChecked: function (table, checked) { //设置节点选中状态
if (this.GetNode(table).length == 1) {
checkboxes[0].checked = checked;
}
},
GetNodeChecked: function (table) { //获取节点选中状态
if (this.GetNode(table).length == 1) {
return checkboxes[0].checked;
}
},
GetNode: function (table) { //获取节点
var checkboxIndex = table.rows[0].cells.length - 1;
var cell = table.rows[0].cells[checkboxIndex];
return checkboxes = cell.getElementsByTagName("INPUT");
}
};
Js Code
后台
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
//调用递归函数,完成树形结构的生成
AddTree(, (TreeNode)null);
this.tv_roleaction.Attributes.Add("onclick", "nodecheck.init()");
}
} //递归添加树的节点
public void AddTree(int ParentID, TreeNode pNode)
{
DataView dvTree = new DataView(SysActionBLL.GetInstance().GetList(""));
//过滤ParentID,得到当前的所有子节点
dvTree.RowFilter = "[FPARENTACTIONID] = " + ParentID; foreach (DataRowView Row in dvTree)
{
TreeNode Node = new TreeNode();
Node.Value = Row["FACTIONID"].ToString();
Node.Text = Row["FACTIONNAME"].ToString();
Node.Expanded = true;
if (pNode == null)
{ //添加根节点
tv_roleaction.Nodes.Add(Node);
}
else
{ //?添加当前节点的子节点
pNode.ChildNodes.Add(Node);
} //判断当前角色是否拥有该权限
if (roleaction.Count > && roleaction.Find(p => p.ToString() == Row["FACTIONID"].ToString()) != null)
{
Node.Checked = true;
}
AddTree(Int32.Parse(Row["FACTIONID"].ToString()), Node); //再次递归
}
} /// <summary>
/// 保存
/// </summary>
protected void btnSave_click(object sender, EventArgs e)
{
//获取选中节点的value集合
List<object> roleaction = new List<object>();
foreach (TreeNode node in tv_roleaction.CheckedNodes)
{
roleaction.Add(node.Value);
}
}
C# Code
asp TreeView控件的使用的更多相关文章
- 【ASP.NET 进阶】TreeView控件学习
这几天上班没事做,也不好打酱油,学点没接触过的新东西吧,基本了解了下TreeView控件. TreeView 控件用于在树结构中显示分层数据,例如目录或文件目录等. 下面看代码吧: 1.效果图 2.静 ...
- ASP.NET - TreeView控件,只操作最后一级节点
效果: 使用母板页进行,左右页面进行跳转. 绑定TreeView控件:http://www.cnblogs.com/KTblog/p/4792302.html 主要功能: 点击节点的时候,只操作最后一 ...
- TreeView控件例子
XmL文件代码: <?xml version="1.0" encoding="utf-8" ?> <Area> <Province ...
- TreeView控件绑定数据库
1.在设计视图里面的代码 <form id="form1" runat="server"> <div> <h1>两个表< ...
- ASP.NET控件属性大全
ASP.NET控件属性大全 DataGridView 控件DataGridView 控件提供用来显示数据的可自定义表.使用 DataGridView 类,可以自定义单元格.行.列和边框. 注意Data ...
- TreeView控件使用
treeView1.SelectedNode = treeView1.Nodes[0]; //选中当前treeview控件的根节点为当前节点添加子节点: TreeNode tmp; tmp = n ...
- 基于Treeview控件遍历本地磁盘
一.前言 Treeview控件常用于遍历本地文件信息,通常与Datagridview与ImageList搭配.ImageList控件用于提供小图片给TreeView控件,DatagridView通常显 ...
- asp.net <asp:Content>控件
<asp:Content ID="Content2" ContentPlaceHolderID="CPH_MainContent" runat=" ...
- Win32中TreeView控件的使用方法,类似于资源管理器中文件树形显示方式
首先是头文件,内容如下: #include <tchar.h> #include "..\CommonFiles\CmnHdr.h" #include <Wind ...
随机推荐
- linux mysql root密码重置
MySQL安装解决方法:重改密码 先停止 Mysql # stop mysql 重要:输入下面的代码# mysqld_safe --user=mysql --skip-grant-tables --s ...
- 用canvas画环形圆形图片
效果如图自动绘制不停歇 代码如下 var canvas = document.getElementById('myCanvas'),width = canvas.width,height = canv ...
- [liusy.api-SMJ]-创建工程范例 MAVEN archetype 学习阶段(一)
由于这个架构需要好多不同能力的工程,为了创建方便减少冗余,创建工程范例尤为重要 学习阶段: 参考资料 http://maven.apache.org/archetype/maven-archetype ...
- NIO SelectionKey中定义的4种事件
SelectionKey.OP_ACCEPT —— 接收连接继续事件,表示服务器监听到了客户连接,服务器可以接收这个连接了 SelectionKey.OP_CONNECT —— 连接就绪事件,表示客户 ...
- Timus 2068. Game of Nuts 解题报告
1.题目描述: 2068. Game of Nuts Time limit: 1.0 secondMemory limit: 64 MB The war for Westeros is still i ...
- AngularJs自定义指令--执行顺序 (原文:http://www.cnblogs.com/sagacite/p/4624227.html)
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- sqlserver查询数据的所有表名和行数
//查询所有表明 select name from sysobjects where xtype='u' select * from sys.tables //查询数据库中所有的表名及行数 SELEC ...
- 详解学习C#的方法和步骤
如果你已经有较多的面向对象开发经验,跳过以下这两步: 第一步 掌握一门.NET面向对象语言,C#或VB.NET. 强烈反对在没系统学过一门面向对象语言的前提下去学ASP.NET. ASP.NET是一个 ...
- If you only do what you can do you'll never be more than you are now.
If you only do what you can do you'll never be more than you are now. 如果你只是做你力所能及的事,你将不会有所进步:
- Python—redis
一.redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sor ...