javascript – IE8上的html2canvas和flashcanvas无法正常工作

我使用html2canvas库来制作表格的png图像.

它适用于Chrome,Firefox和Safari.

代码如下:

$('#myTable').html2canvas ({     
    onrendered : function(canvas) {                           
        var img = canvas.toDataURL('image/png');
        var newWin = window.open('','_blank','width=500,height=400');
        var htmlPage = "";
        htmlPage += "<html>";
        htmlPage += "<head>";
        ...
        htmlPage += "</head>";
        htmlPage += "<body>";
        ...   
        htmlPage += "<img src='"+img+"' width='400px'/>";
        ...   
        htmlPage += "</body>";
        htmlPage += "</html>";
        newWin.document.write(htmlPage);
    }
});

当我用IE8打开页面时,页面不起作用.

我已经读过我应该使用flashcanvas,所以我添加了flashcanvas库并在页面添加了这一行:

<!--[if lt IE 9]>                
   <script type="text/javascript src="../sample/flashcanvas.js"></script>
<![endif]-->

所以,当我用IE8打开页面时,库flashcanvas.js被加载了!

但问题仍然存在! IE8告诉我:

"The object does not support the property or the method 'toDataURL'"

谁能帮我?

解决方法

我不确定canvas元素是如何创建的,但你可能需要在onrendered回调中做这样的事情:

if (typeof FlashCanvas != "undefined") {
    FlashCanvas.initElement(canvas);
}
var img = canvas.toDataURL('image/png');
// etc...

请参阅此处的文档:http://flashcanvas.net/docs/usage

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...