13

2つの要素を持つ単純なシミュレートされた配列があります。

bowl["fruit"] = "apple";
bowl["nuts"] = "brazilian";

次のようなイベントで値にアクセスできます。

onclick = "testButton00_('fruit')">with `testButton00_`

function testButton00_(key){
    var t = bowl[key];
    alert("testButton00_: value = "+t);
}

ただし、非明示的な文字列であるキーを使用してコード内から配列にアクセスしようとすると、未定義になります。エスケープされた「キー」を使用してパラメーターを渡す必要がありますか?

4

3 に答える 3

24

キーは動的に計算された文字列にすることができます。合格したもので機能しないものの例を挙げてください。

与えられた:

var bowl = {}; // empty object

あなたは言うことができます:

bowl["fruit"] = "apple";

または:

bowl.fruit = "apple"; // NB. `fruit` is not a string variable here

あるいは:

var fruit = "fruit";
bowl[fruit] = "apple"; // now it is a string variable! Note the [ ]

または、本当にしたい場合:

bowl["f" + "r" + "u" + "i" + "t"] = "apple";

これらはすべて、bowlオブジェクトに同じ影響を及ぼします。次に、対応するパターンを使用して値を取得できます。

var value = bowl["fruit"];
var value = bowl.fruit; // fruit is a hard-coded property name
var value = bowl[fruit]; // fruit must be a variable containing the string "fruit"
var value = bowl["f" + "r" + "u" + "i" + "t"];
于 2010-03-26T15:31:13.043 に答える
0

私はあなたを理解しているかどうかわかりません。キーが次のような文字列であることを確認できます

if(!key) {
  return;
}
var k = String(key);
var t = bowl[k];

または、キーが存在するかどうかを確認できます。

if(typeof(bowl[key]) !== 'undefined') {
  var t = bowk[key];
}

しかし、機能しないコードを投稿したとは思いませんか?

于 2010-03-26T15:35:20.373 に答える
0

キーをエスケープしたくない場合は、JSONを使用できます。

var bowl = {
  fruit: "apple",
  nuts: "brazil"
};

alert(bowl.fruit);
于 2010-03-26T15:36:08.783 に答える