Динамически добавить printthis кнопку в определенный класс - PullRequest
0 голосов
/ 30 мая 2018

Извините, если я что-то упустил (я новичок в JS).Я хочу использовать плагин PrintThis.js JQuery для добавления кнопки печати в любой div с классом "printdiv".Я использую Jquery для нумерации кнопок и классов div и добавляю необходимый код JQuery к тегу сценария в нижней части страницы.

Вот кодовая ручка, которую я сделал с помощью кода, который я использую.https://codepen.io/hinte019/pen/yEybmG?editors=1010

Вот это также в виде кода

<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" />
        <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
        <script src="printthis/printThis.js"></script>
    </head>
    <body>
        <div class="printdiv"><p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Rem voluptatibus, magni, alias eaque dolor quisquam placeat, similique atque ratione fugiat impedit nam numquam accusantium. Deserunt reiciendis nulla omnis necessitatibus, quo.</p></div>
        <div class="printdiv"><p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Sit labore commodi, magnam corrupti dignissimos hic soluta. Distinctio quod saepe, tempora inventore ipsum, eligendi, dignissimos, eos recusandae perspiciatis odit consequuntur! Optio.</p></div>
        <div class="printdiv"><p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Voluptate distinctio fugiat earum, quibusdam soluta ipsa voluptas porro nostrum cupiditate vel modi nesciunt sint rem, vitae id exercitationem debitis, saepe eius?</p></div>
        <script>
        $(function () {
            // print divs
            var i = 1;
            $("body script").append('$(document).ready(function () {');
            $('.printdiv').each(function(){
                $(this).removeClass('printdiv').addClass('printdiv'+i);
                $('.printdiv'+i).prepend('<button type=\"button'+i + '\" class=\"btn btn-primary printbutton' +i + '\">Print<\/button>');
                var printcode = '\r\n        $(\'.printbutton'+i + '\').click(function () {\r\n            $(\'.printdiv'+i + '\').printThis();\r\n        });';
                $("body script").append(printcode);
                i++;
            });
            $("body script").append('\r\n});');
        });
        </script>
    </body>
</html>

Это приводит к печати

$(document).ready(function () {
    $('.printbutton1').click(function () {
        $('.printdiv1').printThis();
    });
    $('.printbutton2').click(function () {
        $('.printdiv2').printThis();
    });
    $('.printbutton3').click(function () {
        $('.printdiv3').printThis();
    });
});

Полученный код должен быть правильным, а кнопки печати -не работает: (

Ответы [ 2 ]

0 голосов
/ 31 мая 2018

Более простой способ выполнить то, что вы хотите:

Изменить на HTML (включая кнопку печати в исходном коде):

<div class="printdiv">
    <p>Lorem ipsum dolor sit amet</p>
    <button class="btn btn-primary printbutton">Print</button>
</div>
<div class="printdiv">
    <p>consectetur adipisicing elit</p>
    <button class="btn btn-primary printbutton">Print</button>
</div>
<div class="printdiv">
    <p>vitae id exercitationem debitis</p>
    <button class="btn btn-primary printbutton">Print</button>
</div>

jQuery:

$('.printButton').on('click', function(){
    var $parent = $(this).parent('.printdiv');
    $parent.printThis();
});

Этот jQuery говорит о щелчке button, обнаруживает, что родитель button div соответствует классу printDiv, и передает его как селектор для printThis.

Кроме того, я быпредложить перенести весь javascript / jQuery со страницы в его собственный файл.

Таким образом, вы должны иметь:

<script src="path/to/jQuery"></script>
<script src="path/to/printThis"></script>
<script src="path/to/your/custom/javascript"></script>

Важное примечание:

  • Добавление <script> динамически, как правило, не требуется, и это очень окольный способвлияет на DOM.
  • Используйте $.on('click',... вместо $.click.Для $.click создается отдельный обработчик для каждого отдельного элемента, который соответствует селектору и работает только для элементов, уже находящихся в DOM (отсюда ваша проблема в исходном коде).$.on работает для динамически добавляемых элементов
0 голосов
/ 30 мая 2018

Проблема в том, что script в теле, в которое вы добавляете свой код, уже было проанализировано / обработано движком js, поэтому вы не можете изменить его содержимое.

Вы должны создать in-память script и после его заполнения добавьте его в DOM.

$(function() {
  // print divs
  var i = 1;
  var script = $('<script>');
  script.append("$(document).ready(function () {");
  $(".printdiv").each(function() {
    $(this)
      .removeClass("printdiv")
      .addClass("printdiv" + i);
    $(".printdiv" + i).prepend(
      '<button type="button' +
        i +
        '" class="btn btn-primary printbutton' +
        i +
        '">Print</button>'
    );
    var printcode =
      "\r\n        $('.printbutton" +
      i +
      "').on('click', function () {\r\n            $('.printdiv" +
      i +
      "').printThis();\r\n        });";
    script.append(printcode);
    i++;
  });
  script.append("\r\n});");
  script.appendTo('body');
});
...