0

私がやろうとしているのは、同一の 2 つの配列を作成することです。入力フィールドの値を変更してボタンをクリックすると、 2番目の配列の値のみを変更したい。ただし、これを行うと、奇妙な理由で、両方の配列の値が変更されますか? 私が間違っていることは何か分かりますか?

これが私のコードの簡略版です:

Javascript:

var arr1=[],

    arr2=[];

$(':input').each(function()
{
    var id = $(this).attr('id');

    arr1[id] = arr2[id] = {'text': $(this).val()};
});

$('#click').click(function()
{
    $(':input').each(function()
    {
        arr2[$(this).attr('id')].text = $(this).val();
    });

    alert(arr1['whatever'].text + '\n\n' + arr2['whatever'].text);

    return false;
});

HTML:

<input type="text" id="whatever" value="test">
<br><br>
<button type="button" id="click">Click</button>

ここに例があります。つまり、入力フィールドの値を変更しtest2てボタンをクリックすると、両方の配列の値が変更されたことがわかります。

可能であれば、これらの配列の作成方法を変更したくありませんarr[id] = {'text': $(this).val()}。そこに問題がある場合を除きます。

4

3 に答える 3

4

オブジェクト配列に格納しています

arr1[id] = arr2[id] = {'text': $(this).val()};

オブジェクトはByValではなくByRefで取得されるため、単に等しいだけでなく、同じビットのメモリであり、一方を変更すると両方が変更されます。おそらく、このようにしたいと思うでしょう。

var val = $(this).val();
arr1[id] = {'text': val};
arr2[id] = {'text': val};
于 2013-05-26T11:53:21.617 に答える
2

使用するslice()

var array2 = array1.slice(0);
于 2013-05-26T11:50:30.373 に答える
2

double 値を 2 つの異なる変数に代入すると、両方とも同じ値になりますが、一方を変更すると、2 番目も変更されます。

$(':input').each(function() {
    var id = $(this).attr('id'),
        val = $(this).val();
    arr1[id] = {'text': val};
    arr2[id] = {'text': val};
});
于 2013-05-26T11:51:39.620 に答える