首页 > 解决方案 > 让子函数递归

问题描述

我有以下内容:

function getitemfalse(){
    $this.items = $this.users.filter( function(item) {
    if(item.status === false ) {
        return item;
        if( item.children.length > 0 ){
            item.children = getchildrem(item.children, false);
        }
    } });        
},

getchildrem(node, status){
    $children = node.filter( function(item) {
    if(item.status === status ) {
        return item;
        if( item.children.length > 0 ){
            item.children = getchildrem(item.children, status);
        }
    }});      
    return $children;     
},

我希望它遍历所有孩子的孩子等(不仅仅是顶层)。但我不清楚如果我做出那个转换,我如何指代当前的孩子?我将不再需要澄清孩子的索引位置。有什么建议么?

我究竟做错了什么?

https://jsfiddle.net/gerarca/f2nue6p4/

标签: javascript

解决方案


不知道你的输入是什么样子的。但是让你的函数递归来实现结果。

有关平面输出,请参见下面的代码段:

let users = [{name: "1", status: false, children: null}, {name: "2", status: false, children: null}, {name: "3", status: true, children: [{name: "5", status: false, children: null}]}, {name: "4", status: true, children: null}];
let items = [];

function getItem(_users, _status){
  _users.forEach(_user=>{
    if(_user.status!=_status && _user.children && _user.children.length > 0){
      getItem(_user.children, _status);
    }else if(_user.status==_status){
      //_user.children = null;  //You can make it null if you dont want children
      items.push(_user);
    }
  });
  
  return items;
}

console.log(getItem(users, false));

你也可以在这里测试

编辑 1

有关嵌套输出,请参见下面的代码段:

let users = [   
    {
        name: "1", 
        status: false, 
        children: [
            {
                name: "5", 
                status: true, 
                children:null
            }
        ]
    },
    {
        name: "2", 
        status: true, 
        children: [
            {
                name: "6", 
                status: false, 
                children:null
            }
        ]
    },
    {
        name: "3", 
        status: false, 
        children: [
            {
                name: "7", 
                status: true, 
                children:[
                    {
                        name: "9", 
                        status: false, 
                        children:null
                    }
                ]
            }
        ]
    },
    {
        name: "4", 
        status: false, 
        children: [
            {
                name: "8", 
                status: false, 
                children:[
                    {
                        name: "10", 
                        status: true, 
                        children:null
                    }
                ]
            }
        ]
    }
];
let items = [];

function getItem(_parent, _users, _status){
    _users.forEach(_user=>{
    if(_user.status == _status){
      let newUser = Object.create(_user, {});
      newUser.children = [];
        _parent.push(newUser);
      if(_user.children && _user.children.length > 0){
        getItem(newUser.children, _user.children, _status);
      }
    }
  });
  
  return items;
}

console.log(getItem(items, users, false));

你也可以在这里测试


推荐阅读