JS避免对象多层次获取时报错

有时候我们需要访问一个对象较深的层次,但是如果这个对象某个属性不存在的话就会报错,例如:

var data = { a: { b: { c: 'ScriptOJ' } } }
data.a.b.c // => scriptoj
data.a.b.c.d // => 报错,代码停止执行
console.log('ScriptOJ') // => 不会被执行

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

var data = { a: { b: { c: 'ScriptOJ' } } }
safeGet(data, 'a.b.c') // => scriptoj
safeGet(data, 'a.b.c.d') // => 返回 undefined
safeGet(data, 'a.b.c.d.e.f.g') // => 返回 undefined
console.log('ScriptOJ') // => 打印 ScriptOJ

下面是实现方法

const safeGet = (data, path) => {
 if(data== undefined) return undefined;
 
 const pathArr = path.split('.');
 let result = data;
 
 for(let i = 0; i < pathArr.length; i++) {
   if(result[pathArr[i]] == undefined) return undefined;
   result = result[pathArr[i]]; 
 }
 return result
}

2019年09月11日更新
给大家介绍一个lodash函数

import _from 'lodash';

_.get(obj,'a.b.d')

更多用法可以参考这里

posted @ 2019-07-13 17:26  YooHoeh  阅读(463)  评论(0编辑  收藏  举报
被你发现了?