zoukankan      html  css  js  c++  java
  • js调用打印机 打印整体或部分

    有时前端的项目中需要添加打印的功能,首先要知道打印分为整体打印和局部打印两种,而局部打印又可细分为局部打印指定的部分,和局部打印指定部分之外的部分。实例比文字看起来更清晰,下面我将用代码来描述

    1、整体打印

    这是最简单的部分

    <button id="print1">打印全部</button>

       $('#print1').click(function(){
         window.print();
       });

    简单的一行js代码即可搞定

    2、局部打印指定部分

    下面的代码中我们主要用第二个button

    html代码

    	<p>下面是百度的图片</p>
    	<div>
    		
    		<img src="https://ss0.bdstatic.com/5aV1bjqh_Q23odCf/static/superman/img/logo/bd_logo1_31bdc765.png">
    		
    	</div>
    	<button id="print1">打印全部</button>
    	<button id="print2" onclick="doPrint()">打印指定部分(以打印图片为例)</button>
    	<button id="print3">打印除某部分之外的的部分</button>
    

    js代码:

    function doPrint() { 
    		bdhtml=window.document.body.innerHTML; 
    		sprnstr="<!--startprint-->"; //开始打印标识字符串有17个字符
    		eprnstr="<!--endprint-->"; //结束打印标识字符串
    		prnhtml=bdhtml.substr(bdhtml.indexOf(sprnstr)+17); //从开始打印标识之后的内容
    		prnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr)); //截取开始标识和结束标识之间的内容
    		window.document.body.innerHTML=prnhtml; //把需要打印的指定内容赋给body.innerHTML
    		window.print(); //调用浏览器的打印功能打印指定区域
    		window.document.body.innerHTML=bdhtml; // 最后还原页面
    	}
    

    用法:

    比如我想打印html页面中的图片,将上述js代码复制,在html文档中img标签前加上‘<!--startprint-->’,标签后加上‘’<!--endprint-->即可

    图例:

    js代码中的17指的就是‘<!--startprint-->’的长度。

    3.局部打印指定部分之外的内容

    其实原理也很简单,就是在打印前将指定部分隐藏,打印后再将指定的部分显示出来

    js代码:

    	$('#print3').click(function(){
    		$('p').hide();
    		window.print();
    		$('p').show();
    	});
    

     这段代码就是打印除p之外的部分了

  • 相关阅读:
    Defining Database and Instance【数据库与实例】
    安装rlwrap错误的问题解决方法
    ORACLE CONTROL FILE 笔记
    NTP时间服务器配置与解析
    虚拟机下Linux系统安装vmtool工具
    ORACLE clusterware组成
    ORACLE RAC集群硬件资源管理与单节点的区别
    Clusterware后台进程
    oracle数据库重建EM
    微机原理之计算机系统导论
  • 原文地址:https://www.cnblogs.com/lfhy/p/6802781.html
Copyright © 2011-2022 走看看