从Javascript对象中删除单个对象

时间:2013-08-16 14:08:24

标签: javascript

如何根据以下javascript对象中的courseID和endDate删除一个项目?

    window.MyCheckedCourses = [
        { courseID: '123', endDate: '6/7/2010' },
        { courseID: '123', endDate: '3/9/2003' },
        { courseID: '456', endDate: '3/9/2003' }  
    ]; 

2 个答案:

答案 0 :(得分:16)

迭代是必须的。您必须使用.splice()删除相应的项目,并使用break for循环。

var i, id = '123', date = '6/7/2010';
for(var i = 0, il = MyCheckedCourses.length;i<il;i++) {
    if(MyCheckedCourses[i].courseID == id && MyCheckedCourses[i].endDate == date) {
        MyCheckedCourses.splice(i, 1);
        break;
    }
}

你可以创建一个函数并使用这样的参数;

function remove(id, date) {
    for(var i = 0, il = MyCheckedCourses.length;i<il;i++) {
        if(MyCheckedCourses[i].courseID == id && MyCheckedCourses[i].endDate == date) {
            MyCheckedCourses.splice(i, 1);
            break;
        }
    }
}
// Example usage:
remove('123', '6/7/2010');

在Ian comment之后编辑:

我认为你的收藏品有独特的物品。如果不是,你必须遍历所有项目而你必须向后执行它,因为如果你从数组中删除一个元素,它的索引将会改变,迭代将无法正常工作。所以这个函数是一个更安全的版本;

function remove(id, date) {
    for(var i = MyCheckedCourses.length - 1;i >= 0;i--) {
        if(MyCheckedCourses[i].courseID == id && MyCheckedCourses[i].endDate == date) {
            MyCheckedCourses.splice(i, 1);
        }
    }
}
// Example usage:
remove('123', '6/7/2010');

答案 1 :(得分:1)

您可以使用splice删除数组中的元素:MyCheckedCourses.splice(index,length);

一个例子:

MyCheckedCourses=[0,1,2,3];
MyCheckedCourses.splice(1,1);

MyCheckedCourses现在是:[0, 1, 3]

要根据您可以使用的键值查找索引:

// only returns the first found index
function findBy(arr,keys){
  var i = 0,match,len;
  for(i=0,len=arr.length;i<len;i++){
     match=true;
     for(key in keys){
       if(arr[i][key]!==keys[key]){
         match=false;
         break
       }
     }
     if(match===true){
       return i;
     }
  }
  return false;
}
var courses=[
    { courseID: '123', endDate: '6/7/2010' },
    { courseID: '123', endDate: '3/9/2003' },
    { courseID: '456', endDate: '3/9/2003' }  
  ];
var index = findBy(courses,
  {courseID:"123",
   endDate:"3/9/2003"}
);
if(index!==false){
  courses.splice(index,1);
}
console.log(courses);