我有以下数组
var array = {"week1":[{"id":1,"name":"x","mark":"20"},{"id":2,"name":"y","mark":"30"}],"week2":[{"id":1,"name":"x","mark":"40"},{"id":2,"name":"y","mark":"60"},{"id":3,"name":"z","mark":"10"}]}
我还有如下的学生ID数组
var studentId = ["1","2","3"]
我想遍历数组并将丢失的学生ID插入每周并将标记设置为零。
var keys = Object.keys(array);
for(var x =0; x<studentId .length; x++)
{
var boolFlag = false;
for(var i=0; i<keys.length;i++)
{
for(var j=0; j=array [keys[i]].length; j++ )
{
if(studentId [x].id == array [keys[i]][j].id)
{
boolFlag = true;
break;
}
}
if(!boolFlag )
{
array [keys[i]].push({id:studentId [x].id, mark:0});
}
}
}
如果所有星期都不完全包含StudentId,则此方法有效。但是,如果一周中有任何一周包含studentId,那么这将不能正确插入ID。我的代码有什么问题?
预期结果:
var result = {"week1":[{"id":1,"name":"x","mark":"20"},{"id":2,"name":"y","mark":"30"},{"id":3,"mark":"0"}],"week2":[{"id":1,"name":"x","mark":"40"},{"id":2,"name":"y","mark":"60"},{"id":3,"name":"z","mark":"10"}]}
更新
var studentId = [{id:"1", name:"x"},{id:"2", name:"y"},{id:"3", name:"z"}]
答案 0 :(得分:1)
var array = {
"week1":[
{"id":1,"name":"x","mark":"20"},
{"id":2,"name":"y","mark":"30"}
],
"week2":[
{"id":1,"name":"x","mark":"40"},
{"id":2,"name":"y","mark":"60"},
{"id":3,"name":"z","mark":"10"}
]
};
var studentId = [
{id:"1", name:"x"},
{id:"2", name:"y"},
{id:"3", name:"z"}
]
for(var week in array){
for(var stId of studentId){
var weekVal = array[week];
if(!weekVal.filter(function(st){ return st.id == stId.id; })[0])
weekVal.push({id:stId.id, name: stId.name, mark:"0"});
}
}
console.log(array);