【灵犀一指】教你如何安全简介的访问嵌套对象

「身无彩凤双飞翼,心有灵犀一点通。」javascript

如今开始写代码o(╯□╰)ojava

举个例子

不安全的访问

//正常的数据结构
const user = {
    id: 1,
    email: 'carlo@bingshan.com',
    info: {
        name: 'carlo',
        address: {
            country: 'china',
            provinces: 'liaoning',
            city: 'dalian',
            street: 'aaaaaaaa'
        }
    }
}
//缺失一部分
const user = {
    id: 1,
    email: 'carlo@bingshan.com',
    info: {
        name: 'carlo'
    }
}
console.log(user.info.address.city);
//TypeError: Cannot read property 'city' of undefined
复制代码

安全访问方案

方法一

if(user && user.info && user.info.address && user.info.address.city) {
    let cityStr = user.info.address.city;
}else{

}
//或者

let cityStr = user && user.info && user.info.address ? user.info.address.city : '';
复制代码

好长好复杂好low!!!git

方法二

使用或运算github

let cityStr = (((user || {}).info || {}).address || {}).city;
复制代码

仍是很长!!数组

方法三

抽出一个公共方法来判断好了安全

循环

function checkObjSafe(obj) {
  for (let i = 1; i < arguments.length; i++) {
    if (!obj.hasOwnProperty(arguments[i])) {
      return false;
    }
    obj = obj[arguments[i]];
  }
  return true;
}
console.log(checkObjSafe(user,'info','address','city'))
复制代码

for循环明显不是个人风格!!bash

尾递归1

function checkObjSafe(obj, level, ...rest) {
  if (obj === undefined) return false
  if (rest.length == 0 && obj.hasOwnProperty(level)) return true
  return checkObjSafe(obj[level], ...rest)
}

console.log(checkObjSafe(user,'info','address'))
复制代码

ES6彷佛好了一点~数据结构

尾递归2

function checkObjSafe(obj, keys) {
  let rest = keys.shift();
  return obj[rest] && (!keys.length || checkObjSafe(obj[rest], keys));
}

console.log(checkObjSafe(user,['info','address','city']))
复制代码

试试扔个数组进去ui

循环2

function checkObjSafe(obj, s){
    s= s.split('.')
    var objNew= obj[s.shift()];
    while(objNew && s.length) objNew= objNew[s.shift()];
    return objNew;
}

console.log(checkObjSafe(user,'info.address.city'))
复制代码

貌似方便了很多,直接传入字符串就行spa

方法四

ES6大法好

function checkObjSafe( obj, ...keys ) {
    return keys.reduce( ( a, b ) => ( a || { } )[ b ], obj );
}

console.log(checkObjSafe(user,'info','address','city'))
复制代码

方法五

暴力风格

try {
    let cityStr = user.info.address.city;
} catch (error) {
    let cityStr = undefined;
}
复制代码

lodash

_.get(user,'info.address.city')
复制代码

lodash

下一代JS特性

const test = user?.info?. address?. city;
  //目前处在Stage 2阶段,可参考下面的连接⤵️
复制代码

Optional Chaining

相关文章
相关标签/搜索