javascript – AngularJS:将服务注入指令?

我一直在尝试将D3.js与Angular集成,并遵循本教程:
http://www.ng-newsletter.com/posts/d3-on-angular.html

本教程创建了一个包含d3Service的d3模块,并将其注入到指令中.我的应用程序结构略有不同,但每当我尝试注入d3服务时,它在我的指令链接函数中显示为未定义.我可以毫无问题地将d3服务注入我的控制器.这是我正在做的事情:

app.js:

var sentimentApp = angular.module('sentimentApp',[
  'ngRoute','ngSanitize','sentimentAppServices','sentimentAppDirectives','sentimentAppControllers'
]);

在services.js中,我有几个服务,其中一个是d3:

var sentimentAppServices = angular.module('sentimentAppServices',['ngResource'])
// other services
.factory('d3',[function(){
  var d3;
  d3 = // d3 library code here
  return d3; 
}]);

现在在directives.js中:

var sentimentAppDirectives = angular.module('sentimentAppDirectives',['sentimentAppServices']);

sentimentAppDirectives.directive('lsPieChart',['d3',function($compile,d3){
   return {
     // scope & template
     link: function($scope,elem,attr,ctrl) {
       console.log(d3); // undefined
     }
   }

有小费吗?谢谢.

最佳答案
问题是您的暗示依赖项与您实际传入的内容不匹配:

['$compile,d3',d3

所以,你所做的是将d3服务作为变量$compile传递,而不是将任何东西作为变量d3传递.

它可能会帮助您理解这是为了什么.在非缩小代码中,您可以完全取出该数组包装器,如下所示:

app.directive('directiveName',d3) {
  // ....
});

将名称作为字符串传递的要点是因为字符串不会受到缩小的影响.这意味着angular将知道如何在这种情况下注入正确的依赖项:

 ['$compile,function(a,b

a将设置为$compile服务,b将设置为d3服务.

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

相关推荐


kindeditor4.x代码高亮功能默认使用的是prettify插件,prettify是Google提供的一款源代码语法高亮着色器,它提供一种简单的形式来着色HTML页面上的程序代码,实现方式如下: 首先在编辑器里面插入javascript代码: 确定后会在编辑器插入这样的代码: <pre
这一篇我将介绍如何让kindeditor4.x整合SyntaxHighlighter代码高亮,因为SyntaxHighlighter的应用非常广泛,所以将kindeditor默认的prettify替换为SyntaxHighlighter代码高亮插件 上一篇“让kindeditor显示高亮代码”中已经
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高
JS对象如何转为json格式字符串
JS怎么获取图片原始宽高
怎么在click事件中调用多个js函数
js如何往数组中添加新元素
js如何拆分字符串
JS怎么对数组内元素进行求和
JS如何判断屏幕大小
js怎么解析json数据
js如何实时获取浏览器窗口大小
原生JS实现别踩白块小游戏(五)
原生JS实现别踩白块小游戏(一)