当使用jqplot导出bar chart为图片时,会抛出Uncaught InvalidStateError: An attempt was made to use an object that is not, or
is no longer, usable.异常。
原因:经调试,原因是柱状图的横坐标刻度间隔显示,而每个刻度的label是由canvas绘出,不显示的刻度canvas的
width为0,$('#chartID').jqplotToImageStr()方法会根据已有的canvas创建一个新的canvas,然后转换为图片,
此时就会抛出该异常。
解决方法:在调用jqplotToImageStr()方法前,加入下列代码:
var $canvas = $('#chartID').find('canvas');
_.each($canvas, function(item) {
if ($(item).attr('width') == '0') {
$(item).attr('width', '5'); //width不为0即可
}
});
OK,导出横坐标间隔显示的图表成功!