Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Javascript

การเข้าถึงวัตถุ JavaScript ที่ซ้อนกันด้วยคีย์สตริง


คุณสามารถใช้วิธีรับของ lodash เพื่อรับคุณสมบัติในทุกระดับได้อย่างปลอดภัย การรับคุณสมบัติระดับแรกนั้นค่อนข้างตรงไปตรงมา การเข้าถึงคุณสมบัติที่ซ้อนกันนั้นยุ่งยากและคุณควรใช้ไลบรารีที่ทดสอบแล้วเช่น lodash

คุณสามารถเข้าถึงวัตถุที่ซ้อนกันอย่างลึกล้ำได้ด้วยวิธีต่อไปนี้ -

ตัวอย่าง

let _ = require("lodash");
let obj = {
   a: {
      b: {
         foo: "test"
      },
      c: 2
   }
};
console.log(_.get(obj, "a.b.foo"));
console.log(_.get(obj, "a.c"));
console.log(_.get(obj, "a.test"));
console.log(_.get(obj, "a.test.x"));

ผลลัพธ์

สิ่งนี้จะให้ผลลัพธ์ -

test
2
undefined
undefined

คุณยังสามารถเขียนฟังก์ชัน getProp ของคุณเองด้วยวิธีต่อไปนี้ -

const getProp = (object, path) => {
   if (path.length === 1) return object[path[0]];
      else if (path.length === 0) throw error;
   else {
      if (object[path[0]]) return getProp(object[path[0]], path.slice(1));
      else {
         object[path[0]] = {};
         return getProp(object[path[0]], path.slice(1));
      }
   }
};

คุณสามารถใช้มันโดยส่งอาร์เรย์เพื่อเข้าถึงอุปกรณ์ประกอบฉาก

ตัวอย่าง

var obj = {
   level1:{
      level2:{
         level3:{
            name: "Foo"
         }
      },
      anotherLevel2: "bar"
   }
};
console.log(getProp(obj, ["level1", "level2"]));

ผลลัพธ์

สิ่งนี้จะให้ผลลัพธ์ -

{level3: {name: "Foo"}}