私がやろうとしているのは、同一の 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()}
。そこに問題がある場合を除きます。