Angular でこの単純な問題を解決するのに役立つものが見つかりませんでした。ロケーション パスに対して比較が行われている場合、すべての回答がナビゲーション バーに関連しています。
list と を使用して動的テーブルを作成しngRepeat
ました。行をクリックすると、この行に選択されたcssクラスを割り当てて、この行がユーザーによって選択されているという事実を強調表示し、.selected
以前に強調表示された行から削除しようとしています。
選択した行と css クラスの割り当てをバインドする方法がありません。
各row
( ul
)に適用しましたが、変更を適用するng-click="setSelected()"
ためのロジックがありませんfunction
。
私のコード:
var webApp = angular.module('webApp', []);
//controllers
webApp.controller ('VotesCtrl', function ($scope, Votes) {
$scope.votes = Votes;
$scope.statuses = ["Approved","Pending","Trash","Spam"];
$scope.setSelected = function() {
console.log("show");
}
});
//services
webApp.factory('Votes', [function() {
//temporary repository till integration with DB this will be translated into restful get query
var votes = [
{
id: '1',
created: 1381583344653,
updated: '222212',
ratingID: '3',
rate: 5,
ip: '198.168.0.0',
status: 'Pending',
},
{
id: '111',
created: 1381583344653,
updated: '222212',
ratingID: '4',
rate: 5,
ip: '198.168.0.1',
status: 'Spam'
},
{
id: '2',
created: 1382387322693,
updated: '222212',
ratingID: '3',
rate: 1,
ip: '198.168.0.2',
status: 'Approved'
},
{
id: '4',
created: 1382387322693,
updated: '222212',
ratingID: '3',
rate: 1,
ip: '198.168.0.3',
status: 'Spam'
}
];
return votes;
}]);
私のHTML:
<body ng-controller='VotesCtrl'>
<div>
<ul>
<li class="created">
<a>CREATED</a>
</li>
<li class="ip">
<b>IP ADDRESS</b>
</li>
<li class="status">
<b>STATUS</b>
</li>
</ul>
<ul ng-repeat="vote in votes" ng-click="setSelected()">
<li class="created">
{{vote.created|date}}
</li>
<li class="ip">
{{vote.ip}}
</li>
<li class="status">
{{vote.status}}
</li>
</ul>
</div>
</body>
私のCSS(選択したクラスのみ):
.selected {
background-color: red;
}