SteelToe-オブジェクト、脚で私を撃ってはいけません!

SteelToeは、オブジェクトの未定義のプロパティへのアクセスの問題を解決するために設計された小さなjavascriptスニペットです。 これは、ネストされたプロパティにアクセスする場合に特に重要です。 また、autovivificationの可能性も実装します。これにより、目的のプロパティを順番に作成しやすくなります。 一般的に、OOPではかなり健康的な砂糖です。






値を取得する



最初の方法


var object = { info: { name: { first: 'Jonathan', last: 'Clem' } } } steelToe(object)('info')('name')('last')(); // 'Clem' steelToe(object)('info')('features')('hairColor')(); // undefined
      
      





第二の方法


 var object = { info: { name: { first: 'Jonathan', last: 'Clem' } } } steelToe(object).walk('info.name.last'); // 'Clem' steelToe(object).walk('info.features.hairColor'); // undefined
      
      







値の定義



 var jonathan = { info: { name: { first: 'Jonathan', last: 'Clem' } } }, steelToe(jonathan).set('info.name.middle', 'Tyler'); steelToe(jonathan).set('info.favorites.movie', 'Harold & Maude'); jonathan.info.name.middle; // Tyler jonathan.info.favorites.movie; // Harold & Maude
      
      







ここで何が起こっているの



想像してみてください-たとえば、JSONから取得したプロパティの大きなネストを持つ複雑なJavascriptオブジェクトがあるとします。 そして、例えば、次のようなことをする必要があります:



 var fatherFirstNames = []; for (var i = 0; i < families.length; i ++) { var first = families[i].father.info.name.first; if (first) { fatherFirstNames.push(first); } } // TypeError: 'undefined' is not an object (evaluating 'family.father.info.name.first')
      
      







-Bliiin!、あなたが言う-脚の愚かなショット! TypeErrorエラーは簡単に抜け落ちTypeError



。なぜなら、 father



プロパティが定義されていること、または必要なプロパティがあることを保証するものではありません。 通常、この種のエラーを防ぐために、次のような悲惨さを書きます。



 var farherFirstNames = []; for (var i = 0; i < families.length; i++) { var father = families[i].father; if (father && father.info && father.info.name && father.info.name.first) { fatherFirstNames.push(father.info.name.first); } }
      
      







Bueee ... SteelToeがこの問題をいかにエレガントに解決するかをご覧ください!



 var fatherFirstNames = []; for (var i = 0; i < families.length; i++) { var name = steelToe(families[i]).walk('father.info.name.first'); if (name) { fatherFirstNames.push(name); } } fatherFirstNames; // ["Hank", "Dale", "Bill"]
      
      







もうTypeError



ありません! 幸福!



ライブラリは、サイトgithubに表示されます。



All Articles