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

javascript – 将变量传递给带有继承(非隔离)范围的指令的Angularjs

如果我使用孤立的范围,我可以通过一个属性传递一个变量.

<my-directive baz='foo.bar'>

然后,在指令的Javascript

.directive('myDirective',function() {
  return {
    scope: {
      'baz': '='
    }
  }
});

有没有办法做一些类似于继承范围的事情?链接功能只是传递字符串.

现在我正在解析变量,并将其与范围匹配.$parent.似乎应该有一个帮助功能或更简单的方法来做到这一点.

解决方法

使用$eval或$parse:
<my-directive baz='foo.bar'>
.directive('myDirective',function($parse) {
  return {
    scope: true,link: function(scope,element,attrs) {
        console.log(scope.$eval(attrs.baz));
        var model = $parse(attrs.baz);
        console.log(model(scope));
        // if you want to modify the value,use the model,not $eval:
        model.assign(scope,"new value");
    }
  }
});

原文地址:https://www.jb51.cc/js/152549.html

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

相关推荐