实现TreeView单选框CheckBox单选

来源:互联网 发布:淘宝联盟安卓 编辑:程序博客网 时间:2024/06/07 11:50
 

本文参照于:
VS2005 TreeView的checkBox的父子节点级联状态
非常感谢原作者
--------
解决原有TreeView 的 CheckBox 被点击时不能引发服务器端事件
实现当TreeView中父节点的CheckBox的点选状态改变时
回发服务器端
触发TreeView1_TreeNodeCheckChanged(object sender, TreeNodeEventArgs e)事件
从而通过代码来控制子节点的CheckBox的点选状态 一同改变

主要步骤及代码示例如下:
1.TreeView绑定onclick事件
  通过本事件 引发回发
2.在TreeView1_TreeNodeCheckChanged(object sender, TreeNodeEventArgs e)事件
  编写相关代码 控制子节点的CheckBox点选状态
-------------------- HTML 页面部分 -----------------------


 1<html>
 2<head runat="server">
 3    <title>VS2005 TreeView CheckBox</title>
 4    <script type="text/javascript">
 5    // 点击复选框时触发事件
 6    function postBackByObject()
 7    {
 8        var o = window.event.srcElement;
 9        if (o.tagName == "INPUT" && o.type == "checkbox")
10        {
11           __doPostBack("","");
12        }
13    }
14</script>
15</head>
16<body>
17    <form id="form1" runat="server">
18    <div>
19        <asp:TreeView ID="TreeView1" runat="server" OnTreeNodeCheckChanged="TreeView1_TreeNodeCheckChanged">
20            <SelectedNodeStyle BackColor="SlateGray" />         
21        </asp:TreeView>   
22    </div>
23    </form>
24</body>
25</html>

--------------------- cs页面代码 --------------------


 1protected void Page_Load(object sender, EventArgs e)
 2    {
 3        if (!IsPostBack)
 4        {
 5            //构建TreeView
 6            TreeNode Node00 = new TreeNode("00", "00");
 7
 8            TreeNode Node01 = new TreeNode("01", "01");
 9            TreeNode Node0101 = new TreeNode("0101", "0101");
10            TreeNode Node0102 = new TreeNode("0102", "0102");
11            TreeNode Node02 = new TreeNode("02", "02");
12
13            Node01.ChildNodes.Add(Node0101);
14            Node01.ChildNodes.Add(Node0102);
15
16            Node00.ChildNodes.Add(Node01);
17            Node00.ChildNodes.Add(Node02);
18
19            TreeView1.Nodes.Add(Node00);
20
21            TreeView1.ShowCheckBoxes = TreeNodeTypes.All;//显示CheckBox
22           
23            TreeView1.ExpandDepth = 0;
24
25        }
26        //绑定事件
27        TreeView1.Attributes.Add("onclick", "postBackByObject()");
28
29    }
30
31    //
32    protected void TreeView1_TreeNodeCheckChanged(object sender, TreeNodeEventArgs e)
33    {
34        SetChildChecked(e.Node);
35    }
36
37    //
38    private void SetChildChecked(TreeNode parentNode)
39    {
40        foreach (TreeNode node in parentNode.ChildNodes)
41        {
42            node.Checked = parentNode.Checked;
43
44            if (node.ChildNodes.Count > 0)
45            {
46                SetChildChecked(node);
47            }
48        }
49    }
50
51

原创粉丝点击