最佳答案
我在视图中有一个附加ng-click
的项列表:
<ul id="team-filters">
<li ng-click="foo($event, team)" ng-repeat="team in teams">
<img src="{{team.logoSmall}}" alt="{{team.name}}" title="{{team.name}}">
</li>
</ul>
我正在处理指令中的foo
函数中的单击事件,将$event
作为被单击对象的引用传递,但我得到的是对img
标记的引用,而不是li
标记。然后我必须做这样的事情来获得li
:
$scope.foo = function($event, team) {
var el = (function(){
if ($event.target.nodeName === 'IMG') {
return angular.element($event.target).parent(); // get li
} else {
return angular.element($event.target); // is li
}
})();
有没有一种简单的方法来获得ng-click
所绑定的元素的引用,而不需要在我的指令中进行DOM操作?