加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

如何取消订阅angularJS中的广播事件 如何删除通过$ on注册的函数

发布时间:2020-12-17 09:34:21 所属栏目:安全 来源:网络整理
导读:我已经注册我的监听器$广播事件使用$ on函数 $scope.$on("onViewUpdated",this.callMe); 并且我想根据特定的业务规则取消注册此侦听器。但我的问题是,一旦它注册,我不能取消注册它。 在AngularJS中有没有任何方法来取消注册特定的监听器?一个像$ on这样的
我已经注册我的监听器$广播事件使用$ on函数
$scope.$on("onViewUpdated",this.callMe);

并且我想根据特定的业务规则取消注册此侦听器。但我的问题是,一旦它注册,我不能取消注册它。

在AngularJS中有没有任何方法来取消注册特定的监听器?一个像$ on这样的方法,注销此事件,可能是$ off。所以基于业务逻辑我可以说

$scope.$off("onViewUpdated",this.callMe);

并且当某人广播“onViewUpdated”事件时,该函数停止被调用。

谢谢

编辑:
我想从另一个函数注销侦听器。不是我注册它的功能。

您需要存储返回的函数并调用它来取消订阅事件。
var deregisterListener = $scope.$on("onViewUpdated",callMe);
deregisterListener (); // this will deregister that listener

这在源代码:)中至少在1.0.4中找到。我会发布完整的代码,因为它的短

/**
  * @param {string} name Event name to listen on.
  * @param {function(event)} listener Function to call when the event is emitted.
  * @returns {function()} Returns a deregistration function for this listener.
  */
$on: function(name,listener) {
    var namedListeners = this.$$listeners[name];
    if (!namedListeners) {
      this.$$listeners[name] = namedListeners = [];
    }
    namedListeners.push(listener);

    return function() {
      namedListeners[indexOf(namedListeners,listener)] = null;
    };
},

另见,the docs。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读