漫漫技术人生路

C#

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
    现在正在做一个小项目,用的是vs2005,要用到TreeView来管理一些分级数据,并能允许同时选中多个节点,因此需要用到TreeView的ShowCheckBox属性,当我用到的时候才发现,在选中复选框时并不会引起回发事件,这时我就犯愁了,该怎么办呢,从网上查了好多资料,发现有不少是用javascript来实现的TreeView的父子节点级联状态的,但是这些方法都不太适合VS2005的TreeView,于是我继续查阅,发现了一个比较适合VS2005的方法,下面这段话就是从一篇文章(作者是veryhappywx.net里摘录过来的:

【大家会在ASP.NET 2.0使用TreeView控件时发现带有CheckBox控件的TreeNode对象(TreeView节点),选择CheckBox无法回发页面。在MSDN中对于TreeView.TreeNodeCheckChanged事件有一段备注:“当 TreeView 控件的复选框在两次向服务器发送之间更改状态时,会引发 TreeNodeCheckChanged 事件。这使您可以提供一个这样的事件处理方法,即每次发生此事件时执行一个自定义例程(如更新数据库或显示的内容)。尽管 TreeNodeCheckChanged 事件在回发时激发,但更改复选框不会导致回发。”说明框架本身并不能提供一个CheckBox回发的机制,为了实现集联的选择,笔者实现了一种使用JavaScript去回发的方法,变相的解决了这个问题,尽管这样的方法看上去很不美,但是一定程度上能解决我们的实际问题。

 

大致思路,TreeNode对象输出的是一个附和的HTML对象(包括TDAInputCheckBox……),本身没有办法增加客户端脚本,所以为TreeView控件客户端的onclick事件中加入脚本,脚本目的:对于引发事件的对象都做判断,如果是InputCheckBox对象导致的事件,则直接调用__doPostBack来回发页面。】

 

下面就是代码,我做一些扩展,可以实现点击某一个复选框时,设置它的父节点的状态(如果它的父节点的所有子节点都没选中,那么父节点被设置为不选中,否则设置为选中),设置它的所有子节点的状态为它现在的选中状态

 

.aspx文件中加一段JavaScript

 

<script type="text/javascript">

// 点击复选框时触发事件

function postBackByObject()

 

{

    var o = window.event.srcElement;

    if (o.tagName == "INPUT" && o.type == "checkbox")

    {

       __doPostBack("","");

    }

}

</script> 

 

.cs文件

#region 级联父子节点的复选框状态

    /// <summary>

    /// 节点选中状态更改

    /// </summary>

    /// <param name="sender"></param>

    /// <param name="e"></param>

    protected void TreeNodeCheckChanged ( object sender, TreeNodeEventArgs e )

    {

        SetChildChecked ( e.Node );

        // 判断是否是根节点

        if ( !e.Node.Value.Equals ( "0" ) )

        {

            SetParentChecked ( e.Node );

        }

    }

 

    /// <summary>

    /// 根据父节点状态设置子节点的状态

    /// </summary>

    /// <param name="parentNode"></param>

    private void SetChildChecked ( TreeNode parentNode )

    {

        foreach ( TreeNode node in parentNode.ChildNodes )

        {

            node.Checked = parentNode.Checked;

 

            if ( node.ChildNodes.Count > 0 )

            {

                SetChildChecked ( node );

            }

        }

    }

 

    /// <summary>

    /// 根据子节点状态设置父节点的状态

    /// </summary>

    /// <param name="childNode"></param>

    private void SetParentChecked ( TreeNode childNode )

    {

        TreeNode parentNode = childNode.Parent;

        if ( !parentNode.Checked && childNode.Checked )

        {

            parentNode.Checked=true;

        }

        else if(parentNode.Checked && !childNode.Checked)

        {

            int checks = 0;

            foreach ( TreeNode node in parentNode.ChildNodes )

            {

                if ( node.Checked )

                {

                    checks++;

                    break;

                }

            }

 

            if ( checks == 0 )

            {

                parentNode.Checked = false;

                if ( !parentNode.Value.Equals ( "0" ) )

                {

                    SetParentChecked ( parentNode );

                }

            }

        }

    }

 

    #endregion

 希望对大家有用,

posted on 2006-10-26 16:03  javaca88  阅读(1004)  评论(1编辑  收藏  举报