zoukankan      html  css  js  c++  java
  • 调了 好几天的问题 treeview 的js 处理复选框之间的关系,选中子框父框自动选中,单独执行 没问题 放到框架页里 就有问题

    刚开始的js 这么写的

    function OnTreeNodeChecked() {
        var ele = event.srcElement;
        if (ele.type == 'checkbox') {
            var childrenDivID = ele.id.replace('CheckBox', 'Nodes');
            var div = document.getElementById(childrenDivID);
            if (div != null) {
                var checkBoxs = div.getElementsByTagName('INPUT');
                for (var i = 0; i < checkBoxs.length; i++) {
                    if (checkBoxs[i].type == 'checkbox') {
                        checkBoxs[i].checked = ele.checked;
                    }
                }
            }
            OnTreeNodeChildChecked(ele);
    
        }
    }
    function OnTreeNodeChildChecked(ele) {
        //自动处理上级 
           var parentDiv = ele.parentElement.parentElement.parentElement.parentElement.parentElement;
    
        var parentChkBox = document.getElementById(parentDiv.id.replace('Nodes', 'CheckBox'));
        if (parentChkBox != null) {
            var ChildsChkAll = true;
            var Boxs = parentDiv.getElementsByTagName('INPUT');
            var m = 0;
            var n = 0;
            for (var i = 0; i < Boxs.length; i++) {
    
                if (Boxs[i].type == 'checkbox') {
                    m++;
                }
                if (Boxs[i].type == 'checkbox' && Boxs[i].checked == false) {
                    n++
                }
            }
            if (m == n) {
    
                ChildsChkAll = false;
            }
            parentChkBox.checked = ChildsChkAll;
            OnTreeNodeChildChecked(parentChkBox);
        }
    }
        } 
    

      然后 加了个catch 就完事了

    function OnTreeNodeChecked() {
        var ele = event.srcElement;
        if (ele.type == 'checkbox') {
            var childrenDivID = ele.id.replace('CheckBox', 'Nodes');
            var div = document.getElementById(childrenDivID);
            if (div != null) {
                var checkBoxs = div.getElementsByTagName('INPUT');
                for (var i = 0; i < checkBoxs.length; i++) {
                    if (checkBoxs[i].type == 'checkbox') {
                        checkBoxs[i].checked = ele.checked;
                    }
                }
            }
            OnTreeNodeChildChecked(ele);
    
        }
    }
    function OnTreeNodeChildChecked(ele) {
        //自动处理上级 
        try
        {
        var parentDiv = ele.parentElement.parentElement.parentElement.parentElement.parentElement;
    
        var parentChkBox = document.getElementById(parentDiv.id.replace('Nodes', 'CheckBox'));
        if (parentChkBox != null) {
            var ChildsChkAll = true;
            var Boxs = parentDiv.getElementsByTagName('INPUT');
            var m = 0;
            var n = 0;
            for (var i = 0; i < Boxs.length; i++) {
    
                if (Boxs[i].type == 'checkbox') {
                    m++;
                }
                if (Boxs[i].type == 'checkbox' && Boxs[i].checked == false) {
                    n++
                }
            }
            if (m == n) {
    
                ChildsChkAll = false;
            }
            parentChkBox.checked = ChildsChkAll;
            OnTreeNodeChildChecked(parentChkBox);
        }
    }
        catch(e)
        {
        
        
        }
    } 
  • 相关阅读:
    react树节点异步加载和拖拽生成节点
    基于hook的ant design 的tab页的删除功能实现
    dva在hook里effect异步获取数据不同步问题
    SpringBoot整合Rredis
    SpringBoot实现Session共享
    SpringBoot整合Mybatis
    SpringBoot整合JPA多数据源
    SpringData关键字查询方法和自定义查询方法
    SpringBoot整合Mybatis多数据源
    jdbctemplate配置多数据源
  • 原文地址:https://www.cnblogs.com/haihang/p/2748018.html
Copyright © 2011-2022 走看看