我有一个对象数组并希望将其值插入一组输入中。我认为使用jQuery的val()
质量分配这些值在几个for循环,但它只返回两个对象的最后一个值。我究竟做错了什么?更好的是,有没有更好的方式来做到这一点,而不必循环3次?将对象数组中的值插入到一组元素中
$(function() {
var arr = [{v1: 1, v2: 2, v3: 3, v4: 4}, {v1: 5, v2: 6, v3: 7, v4: 8}];
for (var i = 0; i < arr.length; i++) {
for (key in arr[i]) {
$('input').val(function(index) {
return arr[i][key]
});
}
}
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div>
<input type="text" />
<input type="text" />
<input type="text" />
<input type="text" />
</div>
<div>
<input type="text" />
<input type="text" />
<input type="text" />
<input type="text" />
</div>
假设'arr'的结构不能改变是否正确? – Stryner
正确。我从API中检索这些对象,但为了演示而在这里硬编码了一个小阵列。 –