2012-06-20 95 views

回答

6

这是另一种直接进行打印的解决方案。它基于chart.print()函数,但它适用于多个图表。

演示这里:http://jsfiddle.net/jim31415/q5Rzu/150/

 //-------------------------------------------------------------------- 
     $("#print").click(function() { 
      printCharts([chart1, chart2, chart3]); 
     }); 


     //-------------------------------------------------------------------- 
     function printCharts(charts) { 

      var origDisplay = [], 
       origParent = [], 
       body = document.body, 
       childNodes = body.childNodes; 

      // hide all body content 
      Highcharts.each(childNodes, function (node, i) { 
       if (node.nodeType === 1) { 
        origDisplay[i] = node.style.display; 
        node.style.display = "none"; 
       } 
      }); 

      // put the charts back in 
      $.each(charts, function (i, chart) { 
       origParent[i] = chart.container.parentNode; 
       body.appendChild(chart.container); 
      }); 

      // print 
      window.print(); 

      // allow the browser to prepare before reverting 
      setTimeout(function() { 
       // put the charts back in 
       $.each(charts, function (i, chart) { 
        origParent[i].appendChild(chart.container); 
       }); 

       // restore all body content 
       Highcharts.each(childNodes, function (node, i) { 
        if (node.nodeType === 1) { 
         node.style.display = origDisplay[i]; 
        } 
       }); 
      }, 500); 
     } 
    }); 
+0

我会研究它,但从我在jsFiddle中看到的看起来很好! –

+0

Highcharts删除了这些文件,你可以用这个代替第一个链接更好http://jsfiddle.net/q5Rzu/147/ – fcortes

+0

你能帮我吗?我想一次打印5个图表。但我想在第一页的顶部给出一个标题。怎么做 ? –

8

exportChart方法接受参数,因此您可以将它发送给多个图表。但是,打印方法不接受任何参数。因此,要打印,您必须分别指定每个图表,如chart1.print();和chart2.print();它们分别打印它们。

有两种解决方法:

  1. 打印整个页面,而无需使用Highcharts打印。这是一个example

  2. 您可以将两个图表导出到PDF文件,然后在那里打印表格。这里是一个关于如何去export multiple charts to one pdf的例子。

+0

感谢您的回答。这适用于jFiddle,但在我的页面上,这不仅可以打印图表,还可以打印页面上的其他所有内容。我想我可以使用打印CSS来解决问题,但有没有办法只打印图表? –

+0

我已经更新了我的答案。也许它会为你工作。 – Linger

+0

这就是我打算使用的,如果不能从客户端打印多个图表。如果有人有不同的解决方案,我现在就会解决问题。 –