In JavaScript eval() has long known to be evil. Take for example:
function foo(){} foo\["str1"\] = "aaaa"; foo\["str2"\] = "bbbb"; foo\["str3"\] = "ccccc";
Elsewhere you need to lookup items from this structure. Where both “foo” and “str1” are pass in as arguments. So like:
function lookUp(bundle, str) { return eval(bundle\[str\]); }
eval() will invoke a new scope and new compiler just to find and evaluate the string values. There must be a better way. Since foo is defined previously it’s available via the window object. So you can simply say:
function lookUp2(bundle, str) { return window\[bundle\]\[str\]; }
Pretty simple eh?