Echarts3用JS实现保存图片

Echarts3保存图表为图片需要自己实现。用HTML5中给a标签增加了一个download属性,只要有这个属性,点击这个链接时浏览器就不在打开链接指向的文件,而是改为下载(目前只有chrome、firefox和opera支持)。

这个已经有大神实现,点击跳转。这里转转载下大神的代码吧。

但是,上面的实现方法,不支持IE系列,当然微软肯定提供了下载方法,在网上找了方法,最后确定了先用这种实现方法,知乎原文

function saveFileForIE(canvas, fileName) {
    var blob = canvas.msToBlob();
    navigator.msSaveBlob(blob, fileName);
}

这种方法需要先获取到Echarts的canvas,而Echarts的canvas在用户设置的chartId的子节点中,获取方法是
var canvas = document.getElementById(chartId).children[0].children[0];
所以,最终我这个方法是在这样写的。

if(isIE()){
    var allFileName = filename + ".png";
    var canvas = document.getElementById(chartId).children[0].children[0];
    var blob = canvas.msToBlob();
    navigator.msSaveBlob(blob,allFileName);
    return;
}

其实我觉得应该还有别的实现方法,这是微软MSDN的文档。有兴趣或者精力的大神可以研究下。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值