色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

js實現瀏覽器打印功能的示例代碼

瀏覽:80日期:2024-04-30 14:31:55

最近接觸到一個新需求,實現打印機打印小票的功能。打的一桌子小票(慚愧),不過也基本滿足了業務上的需求,現在分享一下如何實現(好記性不如爛筆頭)

先上代碼

// 布局代碼<div id='print'> <div id='print_content'></div></div>//js 部分代碼var f = document.getElementById(’printf’); if (f) { document.getElementById('print_content').removeChild(f); } var printhtml = ` <div style='font-size:12px;margin-left: -6px;'> <p style='margin-left:40px;'>${this.ticket.title}</p> <p>--------------------------------------</p> <p>提貨點:${this.ticket.pickUpAddress}</p> <p>商品名稱:${this.ticket.commodityName}</p> <p>下單時間:${this.ticket.paymentTime}</p> <p>提貨人:${this.ticket.receiver}</p> <p>聯系電話:${this.ticket.receiverPhone}</p> <p>提貨碼:${this.ticket.pickUpCode}</p> <p>提貨時間:${this.ticket.submissionTime}</p> <p style='color:#FFFFFF'>.</p> </div>` if (!!window.ActiveXObject || 'ActiveXObject' in window) { // 針對IE進行適配 var HKEY_Root, HKEY_Path, HKEY_Key; HKEY_Root = 'HKEY_CURRENT_USER'; HKEY_Path = 'SoftwareMicrosoftInternet ExplorerPageSetup'; //設置網頁打印的頁眉頁腳為空 function PageSetup_Null() { var Wsh = new ActiveXObject('WScript.Shell'); HKEY_Key = 'header'; Wsh.RegWrite(HKEY_Root + HKEY_Path + HKEY_Key, ''); HKEY_Key = 'footer'; Wsh.RegWrite(HKEY_Root + HKEY_Path + HKEY_Key, ''); HKEY_Key = 'margin_left' Wsh.RegWrite(HKEY_Root + HKEY_Path + HKEY_Key, '0'); //鍵值設定--左邊邊界HKEY_Key = 'margin_top' Wsh.RegWrite(HKEY_Root + HKEY_Path + HKEY_Key, '0'); //鍵值設定--上邊邊界HKEY_Key = 'margin_right' Wsh.RegWrite(HKEY_Root + HKEY_Path + HKEY_Key, '0'); //鍵值設定--右邊邊界HKEY_Key = 'margin_bottom' Wsh.RegWrite(HKEY_Root + HKEY_Path + HKEY_Key, '0'); //鍵值設定--下邊邊界 } printhtml = ` <div style='font-size:12px;font-weight: 800;height:150px;width:300px'> <p style='margin-left:35px'>${this.ticket.title}</p> <p>------------------------------------------------</p> <p>提貨點:${this.ticket.pickUpAddress}</p> <p>商品名稱:${this.ticket.commodityName}</p> <p>下單時間:${this.ticket.paymentTime}</p> <p>提貨人:${this.ticket.receiver}</p> <p>聯系電話:${this.ticket.receiverPhone}</p> <p>提貨碼:${this.ticket.pickUpCode}</p> <p>提貨時間:${this.ticket.submissionTime}</p> <p style='color:#FFFFFF;font-weight: 100;'>.</p> </div>` } var iframe = document.createElement(’iframe’); iframe.id = ’printf’; iframe.style.width = ’0’; iframe.style.height = ’0’; iframe.style.border = 'none'; document.getElementById('print_content').appendChild(iframe); setTimeout(() => { iframe.contentDocument.write(printhtml); iframe.contentDocument.close(); iframe.contentWindow.focus(); iframe.contentWindow.print(); }, 100)

因為要求不能把打印的數據顯示在頁面上,所以通過iframe的方式去實現。單純的截取字符串重新賦值body內容能進行打印卻把打印的內容展現在頁面中了,所以不行。

打印針對IE的瀏覽器進行了一定程度的調整,IE打印要做特定的處理,詳見上面判斷代碼。打印內容通過模板字符串加內聯樣式去實現。滿足了基本需求。

是否應該也通過截取頁面字符串的方式去做可能比較浪費性能些,為什么這么說?因為樣式在打印的小票上有一定程度的偏差,修了東墻破了西墻,只能采取相對的方式取舍。如果這種寫法不滿足,可以采取截取字符串寫class嘗試。

以上就是js實現瀏覽器打印功能的示例代碼的詳細內容,更多關于js 瀏覽器打印的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 美女视频大全网站免费 | 一级女性全黄久久生活片免费 | 欧美69视频| 黄色三级视频网站 | 欧美一区二区三区精品 | 99视频在线观看免费 | 精品国产高清a毛片 | 中文一区二区在线观看 | 日本特黄特色免费大片 | 国产精品嘿咻嘿咻在线播放 | 久久91综合国产91久久精品 | 亚洲图片 自拍偷拍 | 二区在线观看 | 国产边打电话边做对白刺激 | 免费观看欧美一级牲片一 | 国产精品18久久久久久vr | 欧美在线一级va免费观看 | 国产精品18久久久久久小说 | 男人和女人的做刺激性视频 | 国产视频日韩 | 亚洲理论欧美理论在线观看 | 亚洲无限看 | a毛片在线还看免费网站 | 亚洲 欧美 激情 另类 校园 | 亚洲第一成年网 | 国产精品青草久久久久福利99 | 亚洲天堂视频在线免费观看 | 99久久99这里只有免费费精品 | 国产在线观看免费一级 | 午夜免费片在线观看不卡 | 一本色道久久综合 | 亚洲天堂久久久 | 伊在人亚洲香蕉精品区 | 日韩亚洲欧美一区二区三区 | 毛片免费网址 | 久久久国产99久久国产久 | 欧美成人午夜毛片免费影院 | 亚洲精品国产综合99久久一区 | 日韩国产成人资源精品视频 | 尹人成人 | 午夜三级在线观看 |