首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >angular-nvd3和Browserify

angular-nvd3和Browserify
EN

Stack Overflow用户
提问于 2016-03-31 22:03:52
回答 1查看 161关注 0票数 0

如何让angular-nvd3与Browserify一起工作?我通过npm install angular-nvd3安装,然后使用以下代码创建我的模块。

代码语言:javascript
复制
require('angular').module('myApp', [require('angular-nvd3')]);

我的控制器看起来像

代码语言:javascript
复制
require('angular')
  .module('myApp')
  .controller('MyCtrl', function() {
    var ctrl = this;

    ctrl.nvd3Options = {
        chart: {
            type: 'discreteBarChart',
            height: 450,
            margin : {
                top: 20,
                right: 20,
                bottom: 60,
                left: 55
            },
            // ...other options from demo...
        }
    };

    ctrl.nvd3Data = [{
        key: "Cumulative Return",
        values: [
            { "label" : "A" , "value" : -29.765957771107 },
            // ...other data from demo...
        ]
    }];
  });

我的HTML看起来像这样

代码语言:javascript
复制
<div ng-app="myApp" ng-controller="MyCtrl as ctrl">
  <nvd3 options='ctrl.nvd3Options' data='ctrl.nvd3Data'></nvd3>
</div>

但是我得到的错误是ReferenceError: nv is not defined @ angular-nvd3.js:250 (使用v1.0.5)。

我认为安装并需要angular-nvd3就可以处理所有的依赖项(即nvd3和d3)。但是这些依赖关系并没有得到处理。

当前解决方法

为了解决这个问题,我显式地安装了d3和nvd3,并在我的超文本标记语言中对它们进行了<script> ;(但这正好违背了我的目的。

EN

回答 1

Stack Overflow用户

发布于 2016-03-31 23:24:01

我找到了一个更好的方法。添加

代码语言:javascript
复制
global.d3 = require('d3'); // nvd3 assumes that d3 is global
require('nvd3');

无论您在何处定义模块,并确保将这些包添加到package.json依赖项中。

然后,我只是以通常的方式Browserify (在我的情况下是吞咽)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36335714

复制
相关文章

相似问题

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