JS 使用 window对象的print方法实现分页打印功能


Posted in Javascript onMay 16, 2018

最近做项目用到了web在线打印功能,经研究使用了JS自身支持的Window对象的打印方法,此种方法兼容性比较好,在IE和火狐浏览器下使用都没有问题。 

1.但是网上好多案例都不支持分页功能,最后通过CSS的page-break-after:always样式解决分页问题,以下代码纯个人编写,有需要的朋友可以直接复制到网页中使用,转载请注明出处,谢谢! 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>无标题文档</title> 
<script language="javascript"> 
//打印代码 
 function Print()  
 {  
  var printStr = "<html><head><meta http-equiv='Content-Type' content='text/html; charset=utf-8'></head><body >"; 
  var content = ""; 
  var str = document.getElementById('page1').innerHTML;  //获取需要打印的页面元素 ,page1元素设置样式page-break-after:always,意思是从下一行开始分割。 
  content = content + str; 
  str = document.getElementById('page2').innerHTML;  //获取需要打印的页面元素 
  content = content + str; 
  printStr = printStr+content+"</body></html>";            
  var pwin=window.open("Print.htm","print"); //如果是本地测试,需要先新建Print.htm,如果是在域中使用,则不需要 
  pwin.document.write(printStr); 
  pwin.document.close();     //这句很重要,没有就无法实现 
  pwin.print();  
 } 
</script> 
</head> 
<body > 
<div><input type="button" value="打印" onclick="Print()" /></div> 
<div id="page1"> 
  <table width="100%" border="0" cellpadding="0" cellspacing="0" style="page-break-after:always" > 
  <tr><td>第一页打印内容</td></tr> 
  </table> 
</div> 
<div id="page2"> 
  <table width="100%" border="0" cellpadding="0" cellspacing="0" id="content" > 
  <tr><td>第二页打印内容</td></tr> 
  </table> 
</div> 
</body> 
</html>

总结

以上所述是小编给大家介绍的JS 使用 window对象的print方法实现分页打印功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JS中==与===操作符的比较
Mar 21 Javascript
JQuery的$和其它JS发生冲突的快速解决方法
Jan 24 Javascript
Node.js编码规范
Jul 14 Javascript
利用vue + koa2 + mockjs模拟数据的方法教程
Nov 22 Javascript
JQuery实现table中tr上移下移的示例(超简单)
Jan 08 jQuery
Angular父子组件通过服务传参的示例方法
Oct 31 Javascript
Vue递归实现树形菜单方法实例
Nov 06 Javascript
vue中node_modules中第三方模块的修改使用详解
May 31 Javascript
vue2 拖动排序 vuedraggable组件的实现
Aug 08 Javascript
Emberjs 通过 axios 下载文件的方法
Sep 03 Javascript
JS闭包原理及其使用场景解析
Dec 03 Javascript
js实现滚动条自动滚动
Dec 13 Javascript
Koa2微信公众号开发之消息管理
May 16 #Javascript
js实现鼠标单击Tab表单切换效果
May 16 #Javascript
Koa2微信公众号开发之本地开发调试环境搭建
May 16 #Javascript
解决Mac下安装nmp的淘宝镜像失败问题
May 16 #Javascript
为什么使用koa2搭建微信第三方公众平台的原因
May 16 #Javascript
详解基于Koa2开发微信二维码扫码支付相关流程
May 16 #Javascript
AngularJS标签页tab选项卡切换功能经典实例详解
May 16 #Javascript
You might like
php Ajax乱码
2008/04/09 PHP
解决MySQL中文输出变成问号的问题
2008/06/05 PHP
php split汉字
2009/06/05 PHP
php park、unpark、ord 函数使用方法(二进制流接口应用实例)
2010/10/19 PHP
PHP中数据类型转换的三种方式
2015/04/02 PHP
根据出生日期自动取得星座的js代码
2010/07/20 Javascript
Jquery操作js数组及对象示例代码
2014/05/11 Javascript
jQuery中ajax的load()方法用法实例
2014/12/26 Javascript
JavaScript实现N皇后问题算法谜题解答
2014/12/29 Javascript
javascript 数组操作详解
2015/01/29 Javascript
jquery ui resize 中border-box的bug修正
2015/04/26 Javascript
Bootstrap项目实战之首页内容介绍(全)
2016/04/25 Javascript
AngularJS实现分页显示数据库信息
2016/07/01 Javascript
Three.js学习之Lamber材质和Phong材质
2016/08/04 Javascript
JS for...in 遍历语句用法实例分析
2016/08/24 Javascript
Vue.js实现模拟微信朋友圈开发demo
2017/04/20 Javascript
nodejs集成sqlite使用示例
2017/06/05 NodeJs
详解前端路由实现与react-router使用姿势
2017/08/07 Javascript
ES6中数组array新增方法实例总结
2017/11/07 Javascript
基于vue 动态加载图片src的解决方法
2018/02/05 Javascript
vue-cli监听组件加载完成的方法
2018/09/07 Javascript
vue2和vue3的v-if与v-for优先级对比学习
2020/10/10 Javascript
python如何获取服务器硬件信息
2017/05/11 Python
Python实现的对本地host127.0.0.1主机进行扫描端口功能示例
2019/02/15 Python
运行tensorflow python程序,限制对GPU和CPU的占用操作
2020/02/06 Python
python tkinter的消息框模块(messagebox,simpledialog)
2020/11/07 Python
HTML5单页面手势滑屏切换原理
2016/03/21 HTML / CSS
美国南加州的原创极限运动潮牌:Vans(范斯)
2016/08/05 全球购物
美国家用电器和电子产品商店:Abt
2016/09/06 全球购物
香港网上花店:FlowerAdvisor香港
2019/05/30 全球购物
英国家具、照明、家居用品网上商店:Wayfair.co.uk
2020/02/13 全球购物
Linux开机引导的步骤是什么
2014/02/26 面试题
党员个人总结自评
2015/02/14 职场文书
2015年爱国卫生工作总结
2015/04/22 职场文书
2016年公务员六五普法心得体会
2016/01/21 职场文书
JavaScript 原型与原型链详情
2021/11/02 Javascript