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

业务场景

客户需要在页面有一个打印按钮,点击之后可以打印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查找到对应的元素,将该元素隐藏起来,打印结束之后,再将隐藏的元素显示出来即可。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,671评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,442评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,524评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,623评论 1 275
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,642评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,584评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,953评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,621评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,865评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,608评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,698评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,378评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,958评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,940评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,173评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,419评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,425评论 2 342

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,725评论 1 92
  • 在线阅读 http://interview.poetries.top[http://interview.poetr...
    程序员poetry阅读 114,229评论 24 450
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,404评论 25 707
  • 雨夜寻香醉玉兰, 兰秋舞墨意难安。 安魂曲荡黄泉落, 落腹冰花碎梦间。
    青柘阅读 188评论 0 0
  • 给一年后的你写信,这其实这不是什么新鲜事,地球上无数人干过。我三年前就干过这事儿,不过没有真写,那时候有个咖啡馆办...
    文十言阅读 470评论 2 3