如何创建两个相同的数组,并仅更改其中一个数组的值
How do you create two identical arrays and change the values of just one?
我要做的是创建两个相同的数组。当我更改输入字段中的值并单击按钮时,我只想更改第二个数组中的值。然而,当我这样做时,由于一些奇怪的原因,它改变了中的值两个数组?知道我哪里做错了吗?
下面是我的代码的简化版本:
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()}
。除非这就是问题所在
在数组中存储对象
arr1[id] = arr2[id] = {'text': $(this).val()};
对象是ByRef,而不是ByVal,所以它们不仅仅是相等的,它们是相同的内存位,改变一个会改变两个。你可能想把它们做成这样;
var val = $(this).val();
arr1[id] = {'text': val};
arr2[id] = {'text': val};
使用slice()
var array2 = array1.slice(0);
如果你给两个不同的变量赋双精度值,它们会有相同的值,但是当你改变一个变量时,你也会改变另一个。
$(':input').each(function() {
var id = $(this).attr('id'),
val = $(this).val();
arr1[id] = {'text': val};
arr2[id] = {'text': val};
});
相关文章:
- Javascript(Angular)从一个对象数组到第二个数组查找值
- 根据id将json数组组合为一个json数组
- JavaScript数组包含一个值
- 对一个对象使用reduce可以返回一个没有't在数组中包含目标字母
- jQuery$.inArray()总是返回-1和一个对象数组
- 在数组中的一个元素上设置多个值
- javascript处理一个对象数组以获得一个新的对象数组
- 作为一个二维数组,从ajax接收
- 你能用来自数组的属性名称生成一个对象吗
- 多维关联数组的最后一个索引
- 如何创建一个方法来验证数组的范围
- 循环以检查数组中的最后一个图像
- 在Javascript中将一个值和字符串数组转换为if语句
- 算法:从数组(javascript/angular)中按当前日期获取上一个和下一个事件
- 如何将一个对象添加到每个对象数组中
- 如何创建一个谷歌地图地理坐标数组
- 如何从另一个带下划线的数组中筛选带元素的数组
- 使用window.location.htm和匹配的URL数组(一个用于桌面,一个用于移动)将桌面网站重定向到移动
- Javascript排序多维数组-一个完整的例子
- 刽子手的游戏.2数组.一个需要相应地更新另一个