首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用controllerAs语法修饰angularJS指令控制器函数

使用controllerAs语法修饰angularJS指令控制器函数
EN

Stack Overflow用户
提问于 2017-03-29 18:27:30
回答 1查看 759关注 0票数 2

我正在尝试通过使用$provide.decorator来更改特定供应商指令的行为。

基本指令看起来像这样:

代码语言:javascript
复制
angular
    .module('vendor.module')
    .controller('vendorCtrl', [$scope, function($scope) {
        var vm = this;

        vm.baseFunction = function() {
            //code I want to replace
        }
    }])

    .directive('vendorDir', function() {
      return {
        restrict: 'E',
        controller: 'vendorCtrl as vm',
        scope: {
          stuff: '='
        },
        bindToController: true
      }
    }

    // and this is my decorator
angular
    .module('vendor.module')
    .config(function($provide) {
        $provide.decorator('vendorDirDirective', function($delegate) {
            var directive;
            directive = $delegate[0];

            // how to override vm.baseFunction ?
            return $delegate;
        });
    }

当other指令启动时,我的代码成功运行,但我不确定如何替换控制器中的函数。尝试$scope.baseFunction = function() {}不起作用。

如何更改此函数的行为?

EN

回答 1

Stack Overflow用户

发布于 2018-04-06 04:06:20

试试这样的东西

代码语言:javascript
复制
var _baseFunction = scope.baseFunction;
function baseFunctionExtended() {
    _baseFunction.apply(this, arguments);
    console.log("yay, I'm modified one!");
}
scope.baseFunction = baseFunctionExtended;

这将允许调用原始函数,如果不需要,则不调用,并添加更多内容。下一个问题是如何实现这一点。我想尝试像上面那样扩展链接功能。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43090958

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档