2016-11-22 115 views
0

我有以下格式的數組。我有問題追加每個章節數組內的值。我需要添加像'checked:true'字段。我需要以相同的格式獲取數據。期望的是,需要在章節數組中添加一個字段的相同格式。angularjs將值附加到數組中

{ 
    "Books": [ 
    { 
     "label":"Book1", 
     "data": [ 
     { 
      "bookId": 3561, 
      "bookName": "AJ200", 
      "chapters": [ 
      { 
       "id": 3926, 
       "name": "red" 
      }, 
      { 
       "id": 3927, 
       "name": "yellow" 
      }, 
      { 
       "id": 3928, 
       "name": "black" 
      } 
      ] 
     } 
     ] 
    }, 
    { 
     "label":"Book2", 
     "data":[ 
     { 
      "bookId": 3561, 
      "bookName": "AJ200", 
      "chapters": [ 
      { 
       "id": 3564, 
       "name": "blue" 
      }, 
      { 
       "id": 3565, 
       "name": "orange" 
      } 
      ] 
     } 
     ] 
    } 
    ] 
} 

加場章節陣列看起來像下面後,

"chapters": [ 
      { 
       "id": 3564, 
       "name": "blue", 
       "checked":true 
      }, 
      { 
       "id": 3565, 
       "name": "orange" 
       "checked":true 
      } 
+1

你是如何加入它,張貼代碼 –

+0

你只需要遍歷並添加'checked'財產。 'Array.forEach'就足夠了 – Satpal

回答

1

這是一個有點冗長,但工作原理都是一樣的!

var myObject = 
{ 
    "Books": [ 
    { 
     "label":"Book1", 
     "data": [ 
     { 
      "bookId": 3561, 
      "bookName": "AJ200", 
      "chapters": [ 
      { 
       "id": 3926, 
       "name": "red" 
      }, 
      { 
       "id": 3927, 
       "name": "yellow" 
      }, 
      { 
       "id": 3928, 
       "name": "black" 
      } 
      ] 
     } 
     ] 
    }, 
    { 
     "label":"Book2", 
     "data":[ 
     { 
      "bookId": 3561, 
      "bookName": "AJ200", 
      "chapters": [ 
      { 
       "id": 3564, 
       "name": "blue" 
      }, 
      { 
       "id": 3565, 
       "name": "orange" 
      } 
      ] 
     } 
     ] 
    } 
    ] 
} 

var books = myObject.Books; 


for(var i=0; i<books.length; i++) { 

    var bookData = books[i].data; 

    for(var j=0;j<bookData.length;j++) { 

    var chapters = bookData[j].chapters; 

    for(var k=0;k<chapters.length;k++) { 

     chapters[k].checked = true; 

    } 

    } 

} 

console.log(JSON.stringify(books));