使用jqprint插件实现打印页面内容

作者: 彩虹的夜晚 | 来源:发表于2018-01-06 23:40 被阅读1422次

业务场景

客户需要在页面有一个打印按钮,点击之后可以打印Echarts图表的内容以及文字提示信息,经谷歌搜索发现,实现方法大概有三种之多,其他两种不太熟悉,而采用的这种打印方式是一个在jQuery的基本上开发的一个print插件,因此可以使用jQuery的方式查找元素,因此决定采用这种方式。

先看一下实现的效果图,如下:


实现效果图

引入js文件

<script type="text/javascript" src="__JS__/jquery-migrate-1.2.1.min.js"></script>
<script type="text/javascript" src="__JS__/jqprint-0.3.js"></script>

注意这里是先引入的jQuery文件,如果没有引入第一个js文件的话,会出现兼容性问题,导致使用jqprint打印时报错。

html页面

这里面的html标签很多的
<div class="wrap-content container" id="container">
    <table border="0" cellpadding="0" cellspacing="0" class="store-joinin baseinfo">
        <thead>
            <tr>
                <th colspan="40">用户信息</th>
            </tr>
        </thead>
        <tbody>
            <tr style="background: rgb(255, 255, 255);">
                <th>姓名:</th>
                <td colspan="40">18030632605</td>
            </tr>
            <tr style="background: rgb(255, 255, 255);">
                <th>性别:</th>
                <td colspan="40">男</td>
            </tr>
            <tr style="background: rgb(255, 255, 255);">
                <th>年龄:</th>
                <td colspan="40">41</td>
            </tr>
            <tr style="background: rgb(255, 255, 255);">
                <th>身份证:</th>
                <td colspan="40">52272419770101059X</td>
            </tr>
            <tr style="background: rgb(255, 255, 255);">
                <th>所属机构:</th>
                <td colspan="40">上海市政法委</td>
            </tr>
        </tbody>
      </table>
    ......
    <button class="btn btn-danger printBtn1" onclick="btnPrintClick()" type="button">打 印</button>

当然下面还有很多的html标签,在这里就不展示了。

打印按钮点击之后执行的函数

function btnPrintClick(){
    var imgBox = $('#img_box');
    var chartBox = $('#main');
    if (imgBox.length <= 0) {
        chartBox.after('<div id="img_box"></div>');
        imgBox = $('#img_box');
    }

    // 将echart生成图片并放入img-box,并显示图片img-box
    imgBox.html('< img src="' + myChart.getDataURL() + '"/>').css('display','block');
    // 隐藏echart图chart-box
    chartBox.css('display','none');

    // 调整img大小
    var img = imgBox.find('img');
    var imgWidth = img.width();
    var showWidth = 1000; // 显示宽度,即图片缩小到的宽度
    if (imgWidth > showWidth) { // 只有当图片大了才缩小
        var imgNewHeight = img.height() / (imgWidth / showWidth);
        img.css({'width': showWidth + 'px', 'height': imgNewHeight + 'px'});
    }

    var imgBox2 = $('#img_box2');
    var chartBox2 = $('#main2');
    if (imgBox2.length <= 0) {
        chartBox2.after('<div id="img_box2"></div>');
        imgBox2 = $('#img_box2');
    }

    // 将echart生成图片并放入img-box,并显示图片img-box
    imgBox2.html('< img src="' + myChart2.getDataURL() + '"/>').css('display','block');
    // 隐藏echart图chart-box
        chartBox2.css('display','none');

    // 调整img大小
    var img2 = imgBox2.find('img');
    var img2Width = img2.width();
    var show2Width = 1000; // 显示宽度,即图片缩小到的宽度
    if (img2Width > show2Width) { // 只有当图片大了才缩小
        var img2NewHeight = img2.height() / (img2Width / show2Width);
        img2.css({'width': show2Width + 'px', 'height': img2NewHeight + 'px'});
    }

    // 打印
    $("#TestQuestions").jqprint();

    // 执行打印后再切换回来
    // 显示echart图chart-box
    chartBox.css('display','block');
    chartBox2.css('display','block');
    // 隐藏图片img-box
    imgBox.css('display','none');
    imgBox2.css('display','none');
}

注意事项:

  1. 这里使用了图片的缩放比例的方式。比如Echarts图表要显示的内容特别多的话,一般在html页面中采用的是在X轴上使用滚动条的方式,但是打印时可以将Echarts图表先转换成图片,并等比例进行缩放,打印完毕之后再还原回来即可。

  2. 任何不需要打印的标签都可以先隐藏。对于不需要出现在打印页面的标签内容,我们在打印之前使用jQuery查找到对应的元素,将该元素隐藏起来,打印结束之后,再将隐藏的元素显示出来即可。

相关文章

  • 使用jqprint插件实现打印页面内容

    业务场景 客户需要在页面有一个打印按钮,点击之后可以打印Echarts图表的内容以及文字提示信息,经谷歌搜索发现,...

  • jqPrint 无法打印textArea

    最近一个项目中的打印功能,是使用jqprint插件来实现的,用来打印form表单中的内容。但是使用中发现一个很奇怪...

  • 03jqprint插件打印页面css失效的解决办法

    jqprint插件作为前端一个打印页面插件简单易用,相关配置如下: 如果需要打印的页面引入单个css,meta="...

  • 2018-01-12 引入 jquery-1.4.4.min

    要使用 打印插件 jquery.jqprint-0.3.js,必须引用 jq: jquery-1.4.4.min....

  • jquery实现打印

    jquery实现打印 jquery.jqprint-0.3.js下载 提取码:vxga html css(必须引入...

  • vue实现打印功能

    打印功能可以自己使用原生js(window.print())实现,其次就是使用插件,介绍一个打印插件 vue-pr...

  • jquery中的插件hqprint实现页面局部打印

    jquery中的插件hqprint实现页面局部打印 最近在项目中接到一个需求,是需要打印页面中的表格部分,刚接到这...

  • js实现页面部分内容打印功能

    为了实现页面某个部分的div内容打印,并且打印时样式可能需要修改一下,总结如下方法自用。 页面样式设置注意事项 j...

  • HTML : 表单实现

    作业内容 使用纯html实现考试页面(不使用任何css/js),使用正确合适的标签做出如下的页面效果。内容需要完全...

  • web打印的几种方案

    一、调用WebBrowser进行打印 定义一个打印页面,在其他需要打印的页面调用此页面即可。 定义内容如下: <%...

网友评论

    本文标题:使用jqprint插件实现打印页面内容

    本文链接:https://www.haomeiwen.com/subject/mgbunxtx.html