当我想从我的页面删除记录时,我需要在删除前显示确认消息。为此,我使用了 anchor 和 ng-click='delete()'
来删除这样的行。在这里用户可以多次点击 anchor 。这是一个严重的问题,因为确认弹出窗口呈现多次。我的例子是一个样本。在我的项目中,我遇到了太多这样的问题。我想防止多次单击扩展 ng-click
。
最佳答案
如果我们覆盖 ngClick 指令,那么我们可以保护多次点击。
app.config(['$provide', function ($provide) {
$provide.decorator('ngClickDirective',['$delegate','$timeout', function ($delegate,$timeout) {
var original = $delegate[0].compile;
var delay = 500;
$delegate[0].compile = function (element, attrs, transclude) {
var disabled = false;
function onClick(evt) {
if (disabled) {
evt.preventDefault();
evt.stopImmediatePropagation();
} else {
disabled = true;
$timeout(function () { disabled = false; }, delay, false);
}
}
// scope.$on('$destroy', function () { iElement.off('click', onClick); });
element.on('click', onClick);
return original(element, attrs, transclude);
};
return $delegate;
}]);
}]);
关于html - 防止在angularjs中多次点击,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/30137584/