相关疑难解决方法(0)

从其他控制器调用指令控制器中的方法

我有一个有自己的控制器的指令.请参阅以下代码:

var popdown = angular.module('xModules',[]);

popdown.directive('popdown', function () {
    var PopdownController = function ($scope) {
        this.scope = $scope;
    }

    PopdownController.prototype = {
        show:function (message, type) {
            this.scope.message = message;
            this.scope.type = type;
        },

        hide:function () {
            this.scope.message = '';
            this.scope.type = '';
        }
    }

    var linkFn = function (scope, lElement, attrs, controller) {

    };

    return {
        controller: PopdownController,
        link: linkFn,
        replace: true,
        templateUrl: './partials/modules/popdown.html'
    }

});
Run Code Online (Sandbox Code Playgroud)

这是一个错误/通知/警告的通知系统.我想要做的是从另一个控制器(而不是指令控制器)调用show该控制器上的函数.当我这样做时,我还希望我的链接功能检测到某些属性已更改并执行一些动画.

这里有一些代码来举例说明我的要求:

var app = angular.module('app', ['RestService']);

app.controller('IndexController', function($scope, RestService) {
    var …
Run Code Online (Sandbox Code Playgroud)

javascript jquery angularjs angularjs-directive

118
推荐指数
3
解决办法
10万
查看次数

Angular:使用&调用指令链接函数内的控制器函数

我们遇到的问题是在我们的指令的link函数中使用&符号'&'调用传递给指令的函数.

似乎在控制器上调用了该函数,但在调用中没有传递参数.我们看到的所有示例都涉及通过在模板中创建调用来进行传递.有没有办法从它的模板调用你的指令函数,然后在调用传递给它的控制器函数的指令中做一些事情?

angularjs angularjs-directive

61
推荐指数
2
解决办法
8万
查看次数

如何从作为可重用组件的指令公开公共API?

如果有一个可重用组件的angular指令,那么公开可以从控制器访问的公共API的最佳做法是什么?因此,当有多个组件实例时,您可以从控制器进行访问

angular.directive('extLabel', function {
    return {
        scope: {
            name: '@',
            configObj: '='
        },
        link: function(scope, iElement, iAttrs) {
            // this could be and exposed method
            scope.changeLabel = function(newLabel) {
                scope.configObj.label = newLabel;
            }
        }
    }
});
Run Code Online (Sandbox Code Playgroud)

然后当有:

<ext-label name="extlabel1" config-obj="label1"></ext-label>
<ext-label name="extlabel2" config-obj="label2"></ext-label>
<ext-label name="extlabel3" config-obj="label3"></ext-label>
Run Code Online (Sandbox Code Playgroud)

如何在控制器中访问extLabel2的scope.changeLabel?

是否有意义?

angularjs angularjs-directive angularjs-scope

35
推荐指数
4
解决办法
1万
查看次数

如何从外部控制器的指令调用函数?

似乎网上存在类似问题的一些问题,但没有解决方案适合我.

我有一个指令,让我们说包括这样的函数(在指令中):

link: function(scope, element, attrs) {

     scope.myfunction = function (){
          console.log('function run');
     };
}
Run Code Online (Sandbox Code Playgroud)

女巫我想让它从一个控制器运行(调用它),像这样简单:

$scope.myFunction();
Run Code Online (Sandbox Code Playgroud)

所以我可以从指令代码之外的页面的一部分调用它,让我们这样说:

<button ng-click="myFunction()">Run</button>
Run Code Online (Sandbox Code Playgroud)

可能吗?

javascript angularjs

2
推荐指数
1
解决办法
5591
查看次数