在上述示例中, updateDisabledStatus 函数接受两个数组作为参数。它使用 forEach 方法遍历 arr1 中的每个项,并在回调函数中使用 some 方法检查 arr2 中是否存在与当前项的ID重叠的项。如果存在,则将当前项的 disabled 属性设置为 true ,否则设置为 false 。
上述示例输出的结果为 [{ id: 1, name: “A”, disabled: false }, { id: 2, name: “B”, disabled: true }, { id: 3, name: “C”, disabled: false }] ,在选择另一个项时,重叠项的 disabled 属性设置为 false 。
function updateDisabledStatus(arr1, arr2) {
arr1.forEach(function(item) {
if (arr2.some(function(element) {
return element.id === item.id;
})) {
item.disabled = true;
} else {
item.disabled = false;
}
});
}
// 示例用法
var arr1 = [{ id: 1, name: “A” }, { id: 2, name: “B”, disabled: true }, { id: 3, name: “C” }];
var arr2 = [{ id: 2, name: “D” }, { id: 4, name: “E” }];
updateDisabledStatus(arr1, arr2);
console.log(arr1);