利用jqprint插件打印頁(yè)面內(nèi)容的實(shí)現(xiàn)方法
業(yè)務(wù)場(chǎng)景
客戶(hù)需要在頁(yè)面有一個(gè)打印按鈕,點(diǎn)擊之后可以打印Echarts圖表的內(nèi)容以及文字提示信息,經(jīng)谷歌搜索發(fā)現(xiàn),實(shí)現(xiàn)方法大概有三種之多,其他兩種不太熟悉,而采用的這種打印方式是一個(gè)在jQuery的基本上開(kāi)發(fā)的一個(gè)print插件,因此可以使用jQuery的方式查找元素,因此決定采用這種方式。
先看一下實(shí)現(xiàn)的效果圖,如下:

實(shí)現(xiàn)效果圖
引入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文件,如果沒(méi)有引入第一個(gè)js文件的話(huà),會(huì)出現(xiàn)兼容性問(wèn)題,導(dǎo)致使用jqprint打印時(shí)報(bào)錯(cuò)。
html頁(yè)面
這里面的html標(biāo)簽很多的
<div class="wrap-content container" id="container">
<table border="0" cellpadding="0" cellspacing="0" class="store-joinin baseinfo">
<thead>
<tr>
<th colspan="40">用戶(hù)信息</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>所屬機(jī)構(gòu):</th>
<td colspan="40">上海市政法委</td>
</tr>
</tbody>
</table>
......
<button class="btn btn-danger printBtn1" onclick="btnPrintClick()" type="button">打 印</button>
當(dāng)然下面還有很多的html標(biāo)簽,在這里就不展示了。
打印按鈕點(diǎn)擊之后執(zhí)行的函數(shù)
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');
// 調(diào)整img大小
var img = imgBox.find('img');
var imgWidth = img.width();
var showWidth = 1000; // 顯示寬度,即圖片縮小到的寬度
if (imgWidth > showWidth) { // 只有當(dāng)圖片大了才縮小
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');
// 調(diào)整img大小
var img2 = imgBox2.find('img');
var img2Width = img2.width();
var show2Width = 1000; // 顯示寬度,即圖片縮小到的寬度
if (img2Width > show2Width) { // 只有當(dāng)圖片大了才縮小
var img2NewHeight = img2.height() / (img2Width / show2Width);
img2.css({'width': show2Width + 'px', 'height': img2NewHeight + 'px'});
}
// 打印
$("#TestQuestions").jqprint();
// 執(zhí)行打印后再切換回來(lái)
// 顯示echart圖chart-box
chartBox.css('display','block');
chartBox2.css('display','block');
// 隱藏圖片img-box
imgBox.css('display','none');
imgBox2.css('display','none');
}
注意事項(xiàng):
這里使用了圖片的縮放比例的方式。比如Echarts圖表要顯示的內(nèi)容特別多的話(huà),一般在html頁(yè)面中采用的是在X軸上使用滾動(dòng)條的方式,但是打印時(shí)可以將Echarts圖表先轉(zhuǎn)換成圖片,并等比例進(jìn)行縮放,打印完畢之后再還原回來(lái)即可。
任何不需要打印的標(biāo)簽都可以先隱藏。對(duì)于不需要出現(xiàn)在打印頁(yè)面的標(biāo)簽內(nèi)容,我們?cè)诖蛴≈笆褂胘Query查找到對(duì)應(yīng)的元素,將該元素隱藏起來(lái),打印結(jié)束之后,再將隱藏的元素顯示出來(lái)即可。
屬性
- debug: false, //如果是true則可以顯示iframe查看效果(iframe默認(rèn)高和寬都很小,可以再源碼中調(diào)大),默認(rèn)是false
- importCSS: true, //true表示引進(jìn)原來(lái)的頁(yè)面的css,默認(rèn)是true。(如果是true,先會(huì)找$("link[media=print]"),若沒(méi)有會(huì)去找$("link")中的css文件)
- printContainer: true, //表示如果原來(lái)選擇的對(duì)象必須被納入打印(注意:設(shè)置為false可能會(huì)打破你的CSS規(guī)則)。
- operaSupport: false //表示如果插件也必須支持歌opera瀏覽器,在這種情況下,它提供了建立一個(gè)臨時(shí)的打印選項(xiàng)卡。默認(rèn)是true
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
用jquery修復(fù)在iframe下的頁(yè)面錨點(diǎn)失效問(wèn)題
iframe頁(yè)面沒(méi)有滾動(dòng)條,在父窗體中出現(xiàn)滾動(dòng)條,錨點(diǎn)標(biāo)記就會(huì)失效,用js判斷頁(yè)面是否被嵌套,用js計(jì)算iframe在父窗體位置2014-08-08
基于jquery實(shí)現(xiàn)智能表單驗(yàn)證操作
這篇文章主要為大家詳細(xì)介紹了基于jquery實(shí)現(xiàn)智能表單驗(yàn)證操作的相關(guān)資料,利用jquery實(shí)現(xiàn)了對(duì)一個(gè)表單字段格式的即時(shí)檢查,感興趣的小伙伴們可以參考一下2016-05-05
jQuery UI Datepicker length為空或不是對(duì)象錯(cuò)誤的解決方法
jQuery UI Datepicker length為空或不是對(duì)象錯(cuò)誤的解決方法,需要的朋友可以參考下。2010-12-12
在網(wǎng)站上應(yīng)該用的30個(gè)jQuery插件整理
jQuery插件是網(wǎng)頁(yè)設(shè)計(jì)師最喜歡的。從圖像滑塊,圖像畫(huà)廊和導(dǎo)航插件,它們是如此眾多,如此多樣,如此驚人的和互動(dòng)可以制作美化網(wǎng)站2011-11-11
使用jquery為table動(dòng)態(tài)添加行的實(shí)現(xiàn)代碼
最近,有需要做一個(gè)動(dòng)態(tài)的給table,添加行,用了點(diǎn)時(shí)間,算是做成了。已測(cè)試過(guò),但如果發(fā)現(xiàn)有什么bug,可以留言,歡迎拍磚。大家一起進(jìn)步。2011-03-03
jquery 單擊li防止重復(fù)加載的實(shí)現(xiàn)代碼
li在單擊后調(diào)用ajax加載內(nèi)容然后展開(kāi),li不像button在響應(yīng)了單擊事件后可以設(shè)置為disabled。2010-12-12
jQuery EasyUI tree增加搜索功能的實(shí)現(xiàn)方法
擴(kuò)展jQuery EasyUI tree搜索樹(shù)節(jié)點(diǎn)的方法,使其支持節(jié)點(diǎn)名稱(chēng)的模糊匹配,將不匹配的節(jié)點(diǎn)隱藏。下面通過(guò)本文給大家分享jQuery EasyUI tree增加搜索功能,需要的朋友可以參考下2017-04-04

