1

オブジェクト名 set1 から set4 を取得しました。これらの値を eval() を使用してループ内で動的に変更する必要があります。 「make+set」関数でオブジェクトの値を正常に変更できません。

var set1 = {desc:"111",url:"http://photo1.com"};
var set2 = {desc:"222",url:"http://photo2.com"};
var set3 = {desc:"333",url:"http://photo3.com"};
var set4 = {desc:"444",url:"http://photo4.com"};

function make_set(set,desc,url) {
     set = {};
     set.desc = url;
     set.url = url;
    return set;
}

for (var i = 1; i < 5; i++) {
    tempSet = eval("set"+i);
    tempSet = make_set(tempSet,"new description","new url");
    console.log(tempSet)
};

console.log(set1);
console.log(set2);
console.log(set3);
console.log(set4);

オブジェクトを make_set 関数で上書きしましたが、関数で値を正常に変更できません。関数で間違っていますか? または私は何かを逃した?

Object {desc: "new url", url: "new url"}
Object {desc: "new url", url: "new url"}
Object {desc: "new url", url: "new url"}
Object {desc: "new url", url: "new url"}
Object {desc: "111", url: "http://photo1.com"}
Object {desc: "222", url: "http://photo2.com"}
Object {desc: "333", url: "http://photo3.com"}
Object {desc: "444", url: "http://photo4.com"}
4

2 に答える 2

1

tempSet既存のセットを変更するのではなく、新しいオブジェクトを作成してそれに設定します。

for (var i = 1; i < 5; i++) {
    tempSet = eval('set' + i + ' = make_set(tempSet,"new description","new url")');
    console.log(tempSet);
};

しかし、実際には使用しないでくださいeval

var sets = [];
sets[0] = {desc:"111",url:"http://photo1.com"};
sets[1] = {desc:"222",url:"http://photo2.com"};
sets[2] = {desc:"333",url:"http://photo3.com"};
sets[3] = {desc:"444",url:"http://photo4.com"};

function make_set(desc, url) {
    return {desc:desc, url:url};
}

for (var i = 0; i < 4; i++) {
    sets[i] = make_set("new description","new url");
    console.log(sets[i])
};

console.log(sets[0]);
console.log(sets[1]);
console.log(sets[2]);
console.log(sets[3]);
于 2013-11-14T04:25:27.010 に答える
1

線を取り除くset = {};

渡されたオブジェクトを変更するのではなく、新しいオブジェクトを作成しています。

Live Demo

より詳細な説明については、「なぜこのオブジェクトは、他のものを割り当てるときに参照によって渡されないのですか? 」 への回答を参照してください。

于 2013-11-14T04:25:36.667 に答える