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

Angularjs – 装饰控制器

发布时间:2020-12-17 07:58:12 所属栏目:安全 来源:网络整理
导读:我正在尝试为我的控制器设置一个装饰器.我的目的是介绍我的应用程序中所有控制器的一些常见行为. 我已经将它配置为在Angular 1.2.x中工作,但是从1.3.x开始有一些重大更改,这些更改打破了代码.现在得到的错误是“控制器不是一个功能”. 下面是装饰器的代码:
我正在尝试为我的控制器设置一个装饰器.我的目的是介绍我的应用程序中所有控制器的一些常见行为.

我已经将它配置为在Angular 1.2.x中工作,但是从1.3.x开始有一些重大更改,这些更改打破了代码.现在得到的错误是“控制器不是一个功能”.

下面是装饰器的代码:

angular.module('myApp',['ng'],function($provide) {
    $provide.decorator('$controller',function($delegate) {

        return function(constructor,locals) {

                //Custom behaviour code

                return $delegate(constructor,locals);
            }
        })
    });

Angular 1.2.x – http://jsfiddle.net/3v17w364/2/(工作)
Angular 1.4.x – http://jsfiddle.net/tncquyxo/2/(破碎)

在Angular 1.4.x模块中有 decorator方法,不再需要$provide.decorator.

对于猴子修补API,总是最好使用参数而不是显式枚举它们,它会破坏的可能性要小得多.

angular.module('myApp',['ng']).decorator('$controller',function ($delegate) {
    return function (constructor,locals) {
        var controller = $delegate.apply(null,arguments);

        return angular.extend(function () {
            locals.$scope.common = ...;
            return controller();
        },controller);
    };
});

(编辑:李大同)

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

    推荐文章
      热点阅读