我有三個陣列:學生、型別和標記。我想將這些組合成一個名為 student_marks 的陣列,以獲取每個學生的標記型別。但是物件標記函式是作為字串回傳的,并沒有在javascript中執行,如圖代碼結果所示。
我想得到這個結果:
{student: '2'; totalmarks: '0'; mark: {'typeid'="marks" ,'typeid'="marks" , 'typeid'="marks" }}
因此,作為一個整體的結果陣列 student_marks 將如下所示:
{student: '2'; totalmarks: '0'; mark: {'1'="1" ,'2'="2" , '3'="3" }}
{student: '3'; totalmarks: '0'; mark: {'1'="5" ,'2'="4" , '3'="7" }}
{student: '4'; totalmarks: '0'; mark: {'1'="8" ,'2'="7" , '3'="9" }}
這是我用js撰寫的代碼示例:
let std = [
1, 2, 3, 4
];
let marks = [{
type: '2',
marks: '2'
}, {
type: '1',
marks: '1'
},
{
type: '3',
marks: '3'
}, {
type: '2',
marks: '2'
},
{
type: '1',
marks: '1'
}, {
type: '3',
marks: '3'
},
{
type: '2',
marks: '2'
}, {
type: '1',
marks: '1'
},
{
type: '3',
marks: '3'
}, {
type: '2',
marks: '2'
},
{
type: '1',
marks: '1'
}, {
type: '3',
marks: '3'
}
];
let type = [2, 1, 3];
let ri = 0;
let student_marks = [];
let registrationIds = [];
let total_marks = [];
std.forEach(item => {
registrationIds[ri] = item;
// type[ri]=marks[ri];
// marks:marks[ri];
student_marks.push({
student: item,
mark: () => {
for (let i = 0; i < marks_type.length; i ) {
// m[marks_type[i]]=marks[i][ri];
m = [{
type: marks_type[i],
marks: marks[i]['marks'],
}];
// m:{
// marks_type[i]=marks[i][ri];
// };
}
console.log(m);
return m;
},
// totalmarks: total_marks[ri].value,
});
// totalmark[ri]=total_marks[ri].value;
ri ;
});
console.log(student_marks);
uj5u.com熱心網友回復:
由于 JavaScript 函式是一等公民,這意味著它被視為類似于變數,mark因此物件內部的函式student_marks被分配給它而不是執行。另請注意,回傳值是您提到的字串的函式。為了讓您的代碼正常作業,
- 方法一:
將該函式包裝在某處,然后呼叫它。
const calculateMark = () => {
for (let i = 0; i < marks_type.length; i ) {
// m[marks_type[i]]=marks[i][ri];
m = [{
type: marks_type[i],
marks: marks[i]['marks'],
}];
// m:{
// marks_type[i]=marks[i][ri];
// };
}
console.log(m);
return m;
};
student_marks.push({
student: item,
mark: calculateMark()
// totalmarks: total_marks[ri].value,
});
- 方法二:
使用IIFE
student_marks.push({
student: item,
mark: (() => {
for (let i = 0; i < marks_type.length; i ) {
// m[marks_type[i]]=marks[i][ri];
m = [{
type: marks_type[i],
marks: marks[i]['marks'],
}];
// m:{
// marks_type[i]=marks[i][ri];
// };
}
console.log(m);
return m;
})(),
// totalmarks: total_marks[ri].value,
});
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/436810.html
標籤:javascript 数组 javascript 对象
