Asial Blog

Recruit! Asialで一緒に働きませんか?

JavaScript .(ドット)つなぎのキー文字列でオブジェクトの値にアクセスする

カテゴリ :
フロントエンド(HTML5)
タグ :
JavaScript
Tech
JSON
HTML5
ウェーイ!
どうも、今後はサドルごと自転車がなくなった高橋です。
まだ弊社では導入されておりませんが、15時のビール休憩があればなぁ。と思う日々を過ごしております。

さっそく本題に入ります。

いきなりですが、こんなオブジェクトがあったとします。

  1. var obj = {
  2.         world: {
  3.             japan: {
  4.                 greeting: 'ウィッス!',
  5.                 prefecturesCount: 47
  6.             },
  7.             america: {
  8.                 greeting: 'What\'s up?'
  9.             }
  10.         },
  11.         noworld: 'ウェーイ!!'
  12.     }

obj['world.japan.greeting'] で「ウィッス!」できたらなぁ。。。
と思う場面があったので近いノリのアクセサメソッドを作ってみました。

  1. function getValueByDsvKey (key, obj, dsv) {
  2.         key = key || '';
  3.         obj = obj || {};
  4.         dsv = dsv || '.';
  5.  
  6.         var keys = key.split('.');
  7.         var value = obj;
  8.  
  9.         for (var layer = 0, recursive = keys.length; layer <= recursive - 1; layer++) {
  10.             value = value[keys[layer]];
  11.         }
  12.  
  13.         return value;
  14.     }
  15.  
  16.     alert(getValueByDsvKey('world.japan.greeting', obj)); // ウィッス!


やった!ウィッス!出来ましたね(^_^)

大したコードではないですが、配列に持たせれば階層を意識せずに処理できて便利です。

  1. var accessKeys = [
  2.         'world.japan.greeting',
  3.         'world.america.greeting',
  4.         'world.japan.prefecturesCount',
  5.         'noworld'
  6.     ];
  7.     
  8.     accessKeys.forEach(function (key) {
  9.         alert(getValueByDsvKey(key, obj)) // 順番にアラートされる
  10.     });

ただ、どうすれば obj['world.japan.greeting'] でウィッス!出来るのかが分かりませんでした。
プロパティへのアクセスについてカスタマイズする方法をご存知の方がいたら教えてもらえると嬉しいです(・ω<)

それでは!ウェーイ!!

※ソースコードをまとめました。ChromeのDevTools等にコピペすれば動作確認できます。

  1. var obj = {
  2.         world: {
  3.             japan: {
  4.                 greeting: 'ウィッス!',
  5.                 prefecturesCount: 47
  6.             },
  7.             america: {
  8.                 greeting: 'What\'s up?'
  9.             }
  10.         },
  11.         noworld: 'ウェーイ!!'
  12.     }
  13.  
  14.     var accessKeys = [
  15.         'world.japan.greeting',
  16.         'world.america.greeting',
  17.         'world.japan.prefecturesCount',
  18.         'noworld'
  19.     ];
  20.     
  21.     accessKeys.forEach(function (key) {
  22.         alert(getValueByDsvKey(key, obj)) // 順番にアラートされる
  23.     });
  24.  
  25.     function getValueByDsvKey (key, obj, dsv) {
  26.         key = key || '';
  27.         obj = obj || {};
  28.         dsv = dsv || '.';
  29.  
  30.         var keys = key.split('.');
  31.         var value = obj;
  32.  
  33.         for (var layer = 0, recursive = keys.length; layer <= recursive - 1; layer++) {
  34.             value = value[keys[layer]];
  35.         }
  36.  
  37.         return value;
  38.     }