2013-08-16 37 views
22

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

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

这不是一个对象,它是对象的“数组”。 – mavili

+0

'window.MyCheckedCourses'是一个数组,而不是一个jQuery对象。 –

+4

jQuery在哪里? –

回答

13

迭代是必须的。您必须使用.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'); 

编辑后伊恩的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

虽然'id'让我想到“独特”(我知道标题说“单个对象”,但是可能意味着在几个地方有一个“单一对象”),如果可能存在多个匹配,那么你必须向后(去掉“break”和“)循环 – Ian

+1

你是对的Ian,我要更新我的答案。 –

1

可以使用拼接删除数组中的元素: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);