Javascript
 Computer >> コンピューター >  >> プログラミング >> Javascript

JavaScriptでドット表記文字列を使用してオブジェクトのプロパティを安全に設定する


lodashのsetメソッドを使用して、任意のレベルでプロパティを安全に設定できます。第1レベルのプロパティの設定は非常に簡単です。ネストされたプロパティへのアクセスには注意が必要です。lodashなどのテスト済みのライブラリを使用する必要があります。

次の方法で、深くネストされたオブジェクトを設定できます-

let _ = require("lodash");
let obj = {
   a: {
      b: {
         foo: "test"
      },
      c: 2
   }
};
_.set(obj, "a.b.foo", "test1");
_.set(obj, "a.c", { test2: "bar" });
console.log(obj);

出力

これにより、出力が得られます-

{ a: { b: { foo: 'test1' }, c: { test2: 'bar' } } }

次の方法で独自のsetUpdateProp関数を作成することもできます-

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

配列を渡して小道具にアクセスすることで使用できます。

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

出力

これにより、出力が得られます-

{ level1: { level2: 'FooBar', anotherLevel2: 'bar' } }

  1. JavaScriptでのドット表記とブラケット表記

    ドット表記とブラケット表記はどちらも、JavaScriptのオブジェクトプロパティにアクセスするために使用されます。ドット表記は、読みやすく理解しやすく、冗長性が少ないため、主に使用されます。ドット表記とブラケット表記の主な違いは、ブラケット表記では変数を使用してオブジェクトのプロパティにアクセスできることです。 以下は、JavaScriptでのブラケット表記とドット表記のコードです- 例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"

  2. JavaScriptでのドット表記

    ドット表記は、JavaScriptのオブジェクトプロパティにアクセスするために使用されます。以下は、ドット表記を実装するためのコードです- 例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Documen