首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将回调函数传递给指令

将回调函数传递给指令
EN

Stack Overflow用户
提问于 2015-07-15 20:26:52
回答 4查看 35.2K关注 0票数 19

我试图将回调函数从控制器传递给指令。

下面是回调函数代码:

代码语言:javascript
复制
$scope.onImageSelect = function(image) {
    alert('SET');
    $scope.card.image = image;
};

指令用法:

代码语言:javascript
复制
<google-image-search callback="onImageSelect" />

指令代码:

代码语言:javascript
复制
ngmod.directive('directive', function() {
    return {
        templateUrl: '/templates/template.html',
        scope: {
            callback: '&'
        }
    }
});

模板中的回调用法:

代码语言:javascript
复制
<a data-ng-click="callback(url)"></a>

但是,这给我带来了以下错误:

代码语言:javascript
复制
TypeError: Cannot use 'in' operator to search for 'onImageSelect'

我见过很多类似的问题,但不明白我错在哪里。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2015-07-15 20:29:59

在从指令调用表达式方法时,需要以JSON格式从指令传递参数,还应该更正指令callback属性值,以传递类似于callback="onImageSelect(image)"的函数。

指令用法:

代码语言:javascript
复制
<google-image-search callback="onImageSelect(image)" />

指令模板

代码语言:javascript
复制
<a data-ng-click="callback({image: url})"></a>
票数 30
EN

Stack Overflow用户

发布于 2015-07-16 02:47:14

只需使用:

代码语言:javascript
复制
<google-image-search callback="onImageSelect(image)" />

来自AngularJS开发人员指南的这个示例非常类似于您的案例:http://plnkr.co/edit/hYBxk070sgw54RElyWNq?p=preview

票数 2
EN

Stack Overflow用户

发布于 2018-12-06 10:48:30

下面的代码被测试并工作..

代码语言:javascript
复制
Directive call in html

<taxcode-picker call-back-fun="calculate_tax(a, b)"></taxcode-picker>

样本指令码

代码语言:javascript
复制
{
scope:'&',
link: function (scope, element, attrs) {
 scope.tax = {amount:12, rate:10.50};
 scope.obj = {number:12, value:10};

  scope.call_back = function (tax) {
    scope.callBackFun({a:tax, b:obj});
  }
}

}

样本控制器

代码语言:javascript
复制
app.controller("sample", function($scope){
$scope.calculate_tax = function (tax, obj) {

        console.log("tax "+JSON.stringify(tax));

        console.log("obj "+JSON.stringify(obj));
    }
});
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31440366

复制
相关文章

相似问题

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