关于递归的一些写法

用抛出异常跳出循环

try {
   const recursion = array => {
      array.some(tree => {
        if (this.nodeTypeList.includes(tree.nodeType)) {
          selectable = tree
          throw new Error()
        } else if (tree.children && tree.children.length) {
          recursion(tree.children)
        }
      })
    }
    recursion(this.treeDataPublish)
  } catch (error) {
    console.log(error)
}

用return跳出循环:
1、some:return true适用于找到第一条就跳出的

const recursion = array => {
    return array.some(tree => {
      if (this.nodeTypeList.includes(tree.nodeType)) {
        selectable = tree
        return true
      } else if (tree.children && tree.children.length) {
        return recursion(tree.children)
      }
    })
  }
 recursion(this.treeDataPublish)

这里的需要注意的是 递归里面也要return recursion 否则达不到找到一条就跳出循环的效果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值