Ось приклад. Скажімо, я хочу мати зображення, як на багатьох сайтах. Отже, коли ви клацаєте на ескіз, над усім вашим вікном з’являється чорна накладка, а більша версія зображення зосереджена в ньому. Клацання чорної накладки відхиляє її; клацнувши зображення, викличе функцію, яка показує наступне зображення.
Html:
<div ng-controller="OverlayCtrl" class="overlay" ng-click="hideOverlay()">
<img src="http://some_src" ng-click="nextImage()"/>
</div>
Javascript:
function OverlayCtrl($scope) {
$scope.hideOverlay = function() {
// Some code to hdie the overlay
}
$scope.nextImage = function() {
// Some code to find and display the next image
}
}
Проблема полягає в тому, що з цією установкою, якщо натиснути на зображення, обидва nextImage()
і hideOverlay()
викликаються. Але те, що я хочу, це лише nextImage()
називати.
Я знаю, ви можете захопити та скасувати подію у nextImage()
такій функції:
if (window.event) {
window.event.stopPropagation();
}
... Але я хочу знати, чи є кращий AngularJS спосіб його виконання, який не вимагає від мене цього префіксу всіх функцій на елементах всередині накладання.
onclick
, а не ng-click
.
return false
наприкінці функції