jsPDF не работает в Chrome, только Firefox и Safari

Я пытаюсь экспортировать приложение в PDF с помощью jsPDF. После просмотра веб-страниц, взятия строки кода здесь, раздела там - мне удалось заставить его работать ... немного.

Он работает в 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, но не затаил дыхание. Если вы знаете, как это работает, я полностью за это.

Приветствую вас за любую помощь или предложения, которые вы могли бы предоставить.


person Effect Erik    schedule 24.09.2015    source источник
comment
Проблема может быть связана с запросом на сохранение. Эта проблема предполагает, что filesaverjs.   -  person user650881    schedule 04.06.2019
comment
указывает ли '#presenationArea' на элемент div?   -  person Alon Yampolski    schedule 05.06.2019


Ответы (1)


Эта проблема может быть связана с прекращение поддержки навигации по верхнему фрейму.

Удалить: контент инициировал переходы по верхнему фрейму к URL-адресам данных (удалено)

Мы намерены заблокировать веб-страницы от загрузки данных: URL-адресов в верхнем фрейме с помощью тегов, window.open, window.location и подобных механизмов.

Псевдо-URL-адреса, такие как data :, обычно вводят пользователей в заблуждение. Из-за своей незнакомости эти схемы широко используются для спуфинга и фишинговых атак. В идеале пользователи, просматривающие веб-страницы, должны использовать только две хорошо известные схемы (http и https).

Устарело в M58

Удаление в M60

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

Возможное решение для этого, как описано в упомянутой ветке групп Google, - использовать iFrame.

person Alon Yampolski    schedule 05.06.2019