每日一题(五六)完成一个 safeGet 函数,可以安全的获取无限多层次的数据,一旦数据不存在不会报错,会返回 undefined

本文介绍了一种名为safeGet的安全数据获取函数,该函数能够处理无限多层次的数据结构,并在数据不存在时返回undefined,避免了错误抛出。通过两种实现方式,包括普通遍历和reduce方法,展示了如何在JavaScript中优雅地解决此问题。

完成一个 safeGet 函数,可以安全的获取无限多层次的数据,一旦数据不存在不会报错,会返回 undefined,例如:

var data = {a:{b:{c:'aaa'}}}
safeGet(data,'a.b.c'); //'aaa'
safeGet(data,'a.b.c.d'); //undeifned
safeGet(data,'a.b.c.d.e.f'); //undeifned

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

答案:

1.普通方式遍历

function safeGet(obj,str){
    let arr = str.split('.');
    let temp = obj;
    for(let i = 0;i<arr.length;i++){
        
        let target = temp[arr[i]];
        if(!target) return undefined;
        if(i === arr.length-1){
            return target;
        }
        temp = target;
    }
}

2.reduce 方式

const safeGet = (o,path) =>{
    try{
        return path.split('.').reduce((pre,cur)=>pre[cur],o);
    }catch(e){
        return undefined;
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值