微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – Angular Directive绑定函数带有&不传递参数给控制器

我有一个Box file picker交互的指令.我的指令由两个单独的控制器使用,有可能在将来添加更多.

一旦用户选择文件/文件夹,Box文件选择器就可以设置回调函数,如下所示:

var BoxSelect = new BoxSelect();
// Register a success callback handler
BoxSelect.success(function(response) {
    console.log(response);
});

我的控制器正在使用该指令,并且将成功的回调逻辑作为范围变量,我正在传递给该指令.

我创建了一个plunkr,我在嘲笑Box选择行为

调节器

.controller('myController',function($scope) {
  $scope.onSuccessful = function(message) {
    alert('Success! Message: ' + message);
  };
})

指示

angular.module('myApp',[])
  .controller('myController',function($scope) {
    $scope.onSuccessful = function(message) {
      //message is undefined here
      alert('Success! Message: ' + message);
    };
  })
  .directive('myDirective',function() {
    return {
      restrict: 'A',scope: {
        success: '&'
      },link: function(scope,element) {

        //third party allows to subscribe to success and failure functions
        function ThirdPartySelect() {

        }

        ThirdPartySelect.prototype.success = function(callback) {
          this.callback = callback;

        };

        ThirdPartySelect.prototype.fireSuccess = function() {
          this.callback({
            foo: 'bar'
          });
        };

        var myThirdPartyInstance = new ThirdPartySelect();
        myThirdPartyInstance.success(function(message) {
          //message is still defined here,but not in the controller
          scope.success(message);
        });

        element.on('click',function() {
          myThirdPartyInstance.fireSuccess();
        });

      }
    };
  });

视图

<div ng-controller="myController">
  <button my-directive success="onSuccessful(arg)">Test</button>
</div>

回调函数在控制器内调用,但是参数
未定义

我使用’=’而不是’&’来解决这个问题,但我想知道为什么它不能与’&’因为它应该用于method binding

解决方法

是的,要将控制器功能绑定到您的指令,您必须使用&绑定(表达式绑定),允许该指令调用由DOM属性定义的表达式或函数.

但是在您的指令中,当您调用绑定方法时,函数参数应该是一个对象,在定义函数时,该键与您在控制器中声明的参数相同.

所以在你的指令中,你必须更换:

scope.success(message);

通过:

scope.success({message:message.foo});

然后在您的HTML中,您必须更换:

<button my-directive success="onSuccessful(arg)">Test</button>

通过:

<button my-directive success="onSuccessful(message)">Test</button>

你可以看到Working Plunker

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据复制操作的两种方式。‌在聊深浅拷贝之前咱得了解一下js中的两种数据类型:
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:重建二叉树、反向输出链表每个节点 题目 重建二叉树: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列 {1,2,4,7,3,5,6,8} 和中序遍历序列 {
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须了解的知识点,现在迎来了ES6+的时代,因为箭头函数的出现,所以感觉有必要对 this 问题梳理一下,所以刚好总结一下JavaScript中this指向的问题。
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高