在angularJS中拦截ng-click

在angularJS中拦截ng-click,第1张

在angularJS中拦截ng-click

我在下面放了一个示例指令

http://plnkr.co/edit/GJwK7ldGa9LY90bMuOfl?p=preview

我通过创建一个指令来实现它:

  1. 具有较高的
    priority
    ngClick
    ,所以它被称为前
    ngClick
  2. 使它
    terminal
    不会调用
    ngClick
  3. 监听点击事件,然后评估
    ngClick
    消息(如果消息正常)的值。

作为奖励,您可以传递自己的消息,例如:

<a href="#" ng-click="deleteIt(id)"     /confirm/iation-needed="Really Delete?"        >Delete with custom message</a>

代码如下:

app.directive('/confirm/iationNeeded', function () {  return {    priority: 1,    terminal: true,    link: function (scope, element, attr) {      var msg = attr.confirmationNeeded || "Are you sure?";      var clickAction = attr.ngClick;      element.bind('click',function () {        if ( window.confirm(msg) ) {          scope.$eval(clickAction)        }      });    }  };});

希望有帮助。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5639115.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存