Obj.abc get value 例外処理

通常の開発プロセスでobj.a.b.cは、オブジェクトの深層に含まれる値を取得するために渡すようなメソッドに必ず遭遇しますが、 or aおよびその他のデータ型に遭遇すると、エラーが発生します。また、バックエンドを介してデータベースからデータを取得することもよくありますが、このリンクでは、転送プロセス中にいつか同様の状況が発生するとは言えません。以下では、これが起こらないようにするためのメソッドを手動で記述します。bcnullundefined1'2'trueget

1.get機能

let get = function (obj, path, defaultValue) {
    // 将路径拆分成数组
    let pathArr = path.split('.');
    // 默认是传入的值
    let currentValue = obj;
    for (let i = 1; i < pathArr.length; i++) {
        // 边界1:如果上一次值不是对象,或者为null,或者为undefined,直接返回默认值
        if (typeof currentValue !== 'object' || currentValue === null || currentValue === undefined) {
            return defaultValue;
        }
        // 当前路径
        let path = pathArr[i]
        // 当前key的数组
        let keys = Object.keys(currentValue)
        // 边界2:当前路径不在上一次值的keys中,直接返回默认值
        if (!keys.includes(path)) {
            return defaultValue;
        }
        // 获取当前路径下的值
        currentValue = currentValue[path];
    }
    return currentValue;
}
复制代码

2. テストケース

// 测试1
let obj1 = {
    a: [{
        b: {
            c: 3
        }
    }]
}
console.log(get(obj1, 'obj1.a.0.b.c', -1)) // 3
console.log(get(obj1, 'obj1.a.0.d.c', -1)) // -1
console.log(get(obj1, 'obj1.a.0.b.c.f', -1)) // -1

// 测试2
let obj2 = {
    a: {
        b: null
    }
}
console.log(get(obj2, 'obj2.a.b', -1)) // null
console.log(get(obj2, 'obj2.a.b.c', -1)) // -1
// 测试3
let obj3 = {
    a: {
        b: undefined
    }
}
console.log(get(obj3, 'obj3.a.b', -1)) // undefined
console.log(get(obj3, 'obj3.a.b.c', -1)) // -1
复制代码

おすすめ

転載: juejin.im/post/7190276911371665465