首先准备要打印的内容,也可以打印时再填充,html中定义如下:

  1. <!--startprint-->
  2. <div id="printcontent" style="display:none">
  3. ${printContentBody}
  4. </div>
  5. <!--endprint-->

方法一: 通过开始、结束标记(startprint、endprint)来打印

  1. function doPrint() {
  2. bdhtml=window.document.body.innerHTML;
  3. sprnstr="<!--startprint-->"; //开始打印标识字符串有17个字符
  4. eprnstr="<!--endprint-->"; //结束打印标识字符串
  5. prnhtml=bdhtml.substr(bdhtml.indexOf(sprnstr)+17); //从开始打印标识之后的内容
  6. prnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr)); //截取开始标识和结束标识之间的内容
  7. window.document.body.innerHTML=prnhtml; //把需要打印的指定内容赋给body.innerHTML
  8. window.print(); //调用浏览器的打印功能打印指定区域
  9. window.document.body.innerHTML=bdhtml;//重新给页面内容赋值;
  10. return false;
  11. }

方法二:通过id选择器来替换内容打印,方法类似第一种

  1. function doPrint2(){
  2. if(getExplorer() == "IE"){
  3. pagesetup_null();
  4. }
  5. //根据div标签ID拿到div中的局部内容
  6. bdhtml=window.document.body.innerHTML;
  7. var jubuData = document.getElementById("printcontent").innerHTML;
  8. //把获取的 局部div内容赋给body标签, 相当于重置了 body里的内容
  9. window.document.body.innerHTML= jubuData; 
  10. //调用打印功能
  11. window.print();
  12. window.document.body.innerHTML=bdhtml;//重新给页面内容赋值;
  13. return false;
  14. }
  15.  
  16. function pagesetup_null(){                
  17.     var hkey_root,hkey_path,hkey_key;
  18.     hkey_root="HKEY_CURRENT_USER";
  19.     hkey_path="\\Software\\Microsoft\\Internet Explorer\\PageSetup\\";
  20.     try{
  21.         var RegWsh = new ActiveXObject("WScript.Shell");
  22.         hkey_key="header";
  23.         RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
  24.         hkey_key="footer";
  25.         RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
  26.     }catch(e){}
  27. }
  28.  
  29. function getExplorer() {
  30.     var explorer = window.navigator.userAgent ;
  31.     //ie
  32.     if (explorer.indexOf("MSIE") >= 0) {
  33.         return "IE";
  34.     }
  35.     //firefox
  36.     else if (explorer.indexOf("Firefox") >= 0) {
  37.         return "Firefox";
  38.     }
  39.     //Chrome
  40.     else if(explorer.indexOf("Chrome") >= 0){
  41.         return "Chrome";
  42.     }
  43.     //Opera
  44.     else if(explorer.indexOf("Opera") >= 0){
  45.         return "Opera";
  46.     }
  47.     //Safari
  48.     else if(explorer.indexOf("Safari") >= 0){
  49.         return "Safari";
  50.     }
  51. }

方法三:通过动态创建iframe来打印(推荐的方法)

这里要注意判断iframe是否存在,防止反复使用时,iframe重复创建消耗内存

  1. function doPrint3(){
  2.  
  3. //判断iframe是否存在,不存在则创建iframe
  4. var iframe=document.getElementById("print-iframe");
  5. if(!iframe){
  6. var el = document.getElementById("printcontent");
  7. iframe = document.createElement('IFRAME');
  8. var doc = null;
  9. iframe.setAttribute("id", "print-iframe");
  10. iframe.setAttribute('style', 'position:absolute;width:0px;height:0px;left:-500px;top:-500px;');
  11. document.body.appendChild(iframe);
  12. doc = iframe.contentWindow.document;
  13. //这里可以自定义样式
  14. //doc.write("<LINK rel="stylesheet" type="text/css" href="css/print.css">");
  15. doc.write('<div>' + el.innerHTML + '</div>');
  16. doc.close();
  17. iframe.contentWindow.focus();
  18. }
  19. iframe.contentWindow.print();
  20. if (navigator.userAgent.indexOf("MSIE") > 0){
  21. document.body.removeChild(iframe);
  22. }
  23.  
  24. }

使用方法一、二时,弊端有2个:

1)由于替换来当前页面的内容,从而当取消打印时,会使原来的页面一些form表单失效。

2)当前页面中的样式会影响到打印的内容中的样式。

所以这里推荐使用iframe来创建,并且可以自定义样式。

以上内容在谷歌浏览器下测试通过,其他浏览器未做验证。

-------------------------------------------------------------------------------

190622更新说明:

看到两个伙伴留言,我说说后面发生的事儿吧,我当时做的是电子面单的打印,但是发现第三种方法打印出的电子面单的条码还是不太清洗,字体偏淡。

所以最后也没有用第三种方法,直接使用lodop来打印了。

但是本身第三种方法测试是可行的。

window.print()局部打印三种方式的更多相关文章

  1. 使用javascript实现在页面打印的效果的三种方式

    <div id="console"></div> <script type="text/javascript"> var c ...

  2. 彻底了解构建 JSON 字符串的三种方式

    原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7701856.html 前言:JSON 是轻量级的数据交换格式,很常用,尤其是在使用 Ajax ...

  3. python 全栈开发,Day94(Promise,箭头函数,Django REST framework,生成json数据三种方式,serializers,Postman使用,外部python脚本调用django)

    昨日内容回顾 1. 内容回顾 1. VueX VueX分三部分 1. state 2. mutations 3. actions 存放数据 修改数据的唯一方式 异步操作 修改state中数据的步骤: ...

  4. Python格式化输出的三种方式

    Python格式化输出的三种方式 一.占位符 程序中经常会有这样场景:要求用户输入信息,然后打印成固定的格式比如要求用户输入用户名和年龄,然后打印如下格式:My name is xxx,my age ...

  5. 格式化输出的三种方式,运算符及流程控制之if判断

    ''' 格式化输出的三种方式,运算符及流程控制之if判断 ''' # 格式化输出的三种方式 # 一.占位符 程序中经常会有这样场景:要求用户输入信息,然后打印成固定的格式 比如要求用户输入用户名和年龄 ...

  6. Python实现微信支付(三种方式)

    Python实现微信支付(三种方式) 关注公众号"轻松学编程"了解更多. 如果需要python SDk源码,可以加我微信[1257309054] 在文末有二维码. 一.准备环境 1 ...

  7. Python基础之格式化输出的三种方式

    目录 1. 格式化输出的三种方式 1.1 占位符 1.2 format格式化 1.3 f-string格式化 1. 格式化输出的三种方式 在程序中,需要将输出信息打印成固定的格式,这时候就需要格式化输 ...

  8. iOS字体加载三种方式

    静态加载 动态加载 动态下载苹果提供的多种字体 其他 打印出当前所有可用的字体 检查某字体是否已经下载 这是一篇很简短的文章,介绍了 iOS 自定义字体加载的三种方式. 静态加载 这个可以说是最简单最 ...

  9. JavaScript声明全局变量的三种方式

    JavaScript声明全局变量的三种方式   JS中声明全局变量主要分为显式声明或者隐式声明下面分别介绍. 声明方式一: 使用var(关键字)+变量名(标识符)的方式在function外部声明,即为 ...

随机推荐

  1. java File类中的mkdir()和mkdirs()有什么区别

    mkdir() 只能在已经存在的目录中创建创建文件夹. mkdirs() 可以在不存在的目录中创建文件夹.诸如:a\\b,既可以创建多级目录.

  2. 【转载并整理】Linux - centOS 6 SVN服务器安装、配置及开机启动

    以前在windows上安装svn服务器,用的是VisualSVN-Server用起来还不错,但只能用在windows,在linux上部署使用是 subversion,具体说明如下 参考原文:http: ...

  3. thinkphp的系统变量

    define('EXT', '.php'); define('DS', DIRECTORY_SEPARATOR); defined('THINK_PATH') or define('THINK_PAT ...

  4. 反转链表(不改变指针)JAVA版

    class ListNode { int val; ListNode next; ListNode(int x) { val = x; next = null; } } public class So ...

  5. 星云 Android 开发工具箱

    Toast 工具类: SmartToastUtils.java import android.content.Context; import android.widget.Toast; /** * T ...

  6. Atitit  404错误的排查流程总结 v3 qaf

    Atitit  404错误的排查流程总结 v3 qaf 1.1. 用了注解不生效 提示404 Not Found1 1.2. 路径不对了,开头多了个空格1 2. 500 Servlet Excepti ...

  7. Mac OS X 10.8.5 安装编译glib

    过程比较坎坷,就此记录一番一遍后人 1. 下载pkg-config然后解压安装: ./configure make -j 24 sudo make install 2.下载libiconv解压安装 . ...

  8. Xilinx官网查询各个版本软件的手册

    在Xilinx官网查询各个版本软件的手册需要点击 See All Versions

  9. 【iOS XMPP】使用XMPPFramewok(五):好友列表

    转自:http://www.cnblogs.com/dyingbleed/archive/2013/05/17/3082226.html 好友列表 好友列表,在 XMPP 中被称为 roster,花名 ...

  10. 深入理解Linux内核-虚拟文件系统

    Linux 成功的关键之一是它具有和其他操作系统和谐共存的能力 5个标准文件类型:1.普通文件2.目录文件3.符号链接文件4.设备文件5.管道文件 虚拟文件系统(Virtual FileSystem) ...