jsPDF在Chrome中无法工作,只能在Firefox和Safari中使用。

18

我正在尝试使用jsPDF将一个应用程序导出为PDF文件。在浏览了一些网页并抓取了一些代码段之后,我终于让它运行起来了... 某种程度上

它在Firefox和Safari中可以工作,但在Chrome中无法正常工作。

使用的JS文件(来自jsPDF)。也许有点过多了。还有Jquery。

    <script type="text/javascript" src="PDF/standard_fonts_metrics.js"></script> 
    <script type="text/javascript" src="PDF/split_text_to_size.js"></script>               
    <script type="text/javascript" src="PDF/from_html.js"></script>
    <script type="text/javascript" src="PDF/addhtml.js"></script>               
    <script type="text/javascript" src="PDF/addimage.js"></script>

我使用的代码是这样的:

<script type="text/javascript">
function demoFromHTML() {
  $('#listAreaPDF').css("display", "block");

  var pdf = new jsPDF('p', 'pt', 'letter');
  // source can be HTML-formatted string, or a reference
  // to an actual DOM element from which the text will be scraped.
  source = $('#listAreaPDF')[0];

  pdf.setFontSize(24);
  pdf.text(35, 40, "PDF Title here");

  pdf.setFontSize(10);
  pdf.text(500, 40, "Company Name AB");

  // we support special element handlers. Register them with jQuery-style 
  // ID selector for either ID or node name. ("#iAmID", "div", "span" etc.)
  // There is no support for any other type of selectors 
  // (class, of compound) at this time.
  specialElementHandlers = {
    // element with id of "bypass" - jQuery style selector
    '#bypassme': function (element, renderer) {
      // true = "handled elsewhere, bypass text extraction"
      return true
    }
  };
  margins = {
    top: 80,
    bottom: 60,
    left: 40,
    width: 522
  };


  // all coords and widths are in jsPDF instance's declared units
  // 'inches' in this case
  pdf.fromHTML(
    source, // HTML string or DOM elem ref.
    margins.left, // x coord
    margins.top, {// y coord
      'width': margins.width, // max width of content on PDF
      'elementHandlers': specialElementHandlers
    },
    function (dispose) {
      html2canvas($("#presentationArea"), {
        onrendered: function (canvas) {
          var imgData = canvas.toDataURL(
            'image/png');

          pdf.addImage(imgData, 'PNG', 20, 300);
          pdf.save('Test.pdf');
        }
      });
      // dispose: object with X, Y of the last line add to the PDF 
      // this allow the insertion of new lines after html
      // pdf.save('Test.pdf');
    },
    margins
  );
  $('#listAreaPDF').css("display", "none");
}
</script>

参考此处的代码,感谢原作者。我对代码进行了少量更改以适应我的应用程序,并添加了与html2canvas的连接,将图像提取到PDF中。在Safari和Firefox中,它实际上运行良好。

但是,在Chrome中点击并激活此功能时,我甚至没有收到一个空白的PDF,什么也没有。甚至没有弹出窗口或生成页面。

为什么Firefox和Safari可以工作,但Chrome不行?我还没有尝试Internet Explorer,但我并不抱有希望。 如果您知道一种方法可以使其工作,我非常愿意尝试。

感谢您所提供的任何帮助或建议。


问题可能与保存请求有关。这个问题表明filesaverjs可能会有所帮助。 - user650881
'#presentationArea' 指向一个 div 元素吗? - Alon Yampolski
1个回答

5

这个问题可能与Chrome的顶部框架导航被弃用有关。

移除:使用标签、window.open、window.location和类似机制启动的顶部框架导航到数据URL(已删除)。

我们打算阻止网页使用标签、window.open、window.location等机制在顶层框架中加载数据URL。

伪URL(如data:)通常是用户困惑的来源。由于它们的不熟悉程度,这些计划广泛用于欺诈和网络钓鱼攻击。浏览Web的用户理想情况下只会进入两种众所周知的方案(http和https)。

从M58开始弃用

M60中删除

https://www.chromestatus.com/feature/5669602927312896

一个可能的解决方案是,如在提到的google群组讨论中所描述的那样,使用一个iFrame。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接