Ionic 2 - ng2-chartjs2在浏览器上工作,但不在设备中

时间:2016-10-20 09:21:36

标签: angular ionic2 ng2-charts

我已设法在我的ionic2应用程序中实现ng2-chartjs2。当我在浏览器上运行它(即离子服务或离子运行android -l -c)时它完全正常工作但是当我在设备上尝试它(即离子运行android)时,它只显示一个空白页面。

我上传了工作示例项目in my repo here

任何帮助将不胜感激。感谢。

仍然希望有人能够解决这个问题。

1 个答案:

答案 0 :(得分:2)

这里的问题是Chart.bundle.js不在android构建的预期路径上。

添加:

var availablePlatforms = (process.env.CORDOVA_PLATFORMS ? process.env.CORDOVA_PLATFORMS.split(',') : []);

var filestocopy = [
  {"src/assets/libs/Chart.bundle.js": "platforms/android/assets/libs/Chart.bundle.js"}
];

for(var x=0; x<availablePlatforms.length; x++) {

  var currentPlatform = availablePlatforms[x].trim().toLowerCase();

  if (currentPlatform == 'android') {
    filestocopy.forEach(function(obj) {
      Object.keys(obj).forEach(function(key) {
        var val = obj[key];
        var srcfile = path.join(rootdir, key);
        var destfile = path.join(rootdir, val);
        var destdir = path.dirname(destfile);
        if (fs.existsSync(srcfile) && fs.existsSync(destdir)) {
          fs.createReadStream(srcfile).pipe(
              fs.createWriteStream(destfile));
        }
      });
    });

  }
}

hooks -> after_prepare -> 010_add_platform_class.js的末尾,然后将 index.html 内的脚本引用更改为<script src="assets/libs/Chart.bundle.js"></script>(注意:图表的已更改图表)。

祝你好运!