原来的错误的写法(导致最后的arr数组一直是重复的同样的值,也就是只有最后一条数据)
//处理表格数据,传进来的是json和datagrid中field的值(注意field的值要和json中的数据对上)
function addData(obj,Arr){
//创建arr数组,用来存储pro,以形成[{},{}]这种格式的数据用来满足datagrid的数据格式需求
//创建pro对象,用来存储传参进来的作为属性的field值和作为其属性值的obj的属性值(就是val数组)
//创建val数组,用来存储obj的属性值
var arr = [],pro = {},val = [];
$.each(obj, function(i,n) {
//循环json,取出属性值
for (var key in n) {
//将json的属性值追加到val数组中
val.push(n[key]);
}
//循环传进来的作为属性的field数组
$.each(Arr, function(index,value) {
//通过[]的方式为pro添加属性,value是可变的,根据传进来的参数决定
//val[index]依次为pro的属性添加对应的值
pro[value] = val[index];
});
//可以看到,这里pro就已经成为了我们想要的数据格式
//console.log(pro);
arr.push(pro);
});
$("#dg").datagrid({
data: arr,
selectOnCheck:false
})
}
改进后的方法,其实只改了几句话&#x