У меня есть вложенная JSON структурирована следующим образом:как удалить (сращивание) элемент из вложенного JSON с помощью AngularJS
[{
"phone_id" : "1",
"phone_name" : "nokia",
"phone_img" : "/src/imgs/nokia.jpg",
"phone_comments" :
[
{
"comment_id" : "1",
"user_id" : "32508",
"comment_date" : "2001-02-01",
"user_comment" : "This was the first phone that was rock solid from Nokia"
},
{
"comment_id" : "2",
"user_id" : "32518",
"comment_date" : "2001-02-02",
"user_comment" : "Great phone before the smartphone age"
},
{
"comment_id" : "3",
"user_id" : "22550",
"comment_date" : "2002-04-01",
"user_comment" : "Reminds me of my grandpa's phone"
},
{
"comment_id" : "4",
"user_id" : "31099",
"comment_date" : "2001-05-11",
"user_comment" : "It was a crappy one!"
}
]
}
]
дисплейной часть (работа) - я м способен отображать изображение телефона на 1-й таблице столбец и на ng-click Я загружаю второй столбец с информацией о телефоне с комментариями. Это прекрасно работает.
Deletion (not working) - У меня есть вопрос об удалении комментариев. Я не хочу удалять весь телефонный объект, но только конкретные комментарии. Могу ли я передать что-то вроде ???
remove(comment, $index)
а затем есть функция, которая выполняет следующие действия?
$scope.remove = function (index, comments) {
alert(comments.user_comment + index);
$scope.comments.splice(index, 1);
}
Для справки, HTML выглядит примерно так:
<div ng-app="angularJSApp">
<div ng-controller="PhoneCtrl">
<br/><br/><br/>
<table width="100%" border="1">
<tr ng-repeat="ph in phones">
<td width="20%"><a href="#" ng-click="showComments = ! showComments"><img width="50%" ng-src="{{ph.phone_img}}"></a></td>
<td>
<p>Phone Id: {{ph.phone_id}}</p>
<p>Phone Name: {{ph.phone_name}}</p>
<p>Number of comments: {{ph.phone_comments.length}}</p>
<div class="shComments" ng-show="showComments">
<p>Search: <input ng-model="query"></p>
<table border="1" width="100%">
<thead>
<tr>
<th><a href="" ng-click="predicate = 'comment_id'; reverse = !reverse">Id</a></th>
<th><a href="" ng-click="predicate = 'user_comment'; reverse = false">Comment</a>
(<a href="" ng-click="predicate = '-user_comment'; reverse = false">^</a>)
</th>
<th><a href="" ng-click="predicate = 'comment_date'; reverse = !reverse">Date</a></th>
<th><a href="" ng-click="predicate = 'user_id'; reverse = !reverse">User</th>
<th></th>
</tr>
</thead>
<tbody>
<tr ng-repeat="comment in ph.phone_comments | filter:query | orderBy:predicate:reverse">
<th>{{comment.comment_id}}
<th>{{comment.user_comment}}</th>
<th>{{comment.comment_date}}</th>
<th>{{comment.user_id}}</th>
<th><button ng-click="remove($index, comment)">Remove Comment</button>
</tr>
</tbody>
</table>
</div>
</td>
</tr>
</table>
</div>
</div>
P.S: Я экспериментировал с AngularJS и я спрашиваю это после того, как искал решения столько, сколько я могу. Спасибо за вашу помощь.
Спасибо за ответ. Но это не работает для меня. Не могли бы вы взглянуть на http://plnkr.co/edit/gcA5MgshB9wriGM9sKEF?p=preview –
Причина, по которой это не работает, потому что вам нужны два индекса: один для телефона и один для комментария в пределах данные телефона структурированы. Я отредактировал свой ответ, чтобы дать вам представление. – rdodev