window.print打印指定div指定网页指定区域的方法
第一种方法:指定不打印区域
使用CSS,定义一个.noprint的class,将不打印的内容放入这个class内。
细如下:
<stylemedia=printtype="text/css"> .noprint{visibility:hidden} </style>
要打印的内容。哈哈!
<pclass="noprint">将不打印的代码放在这里。</p> <ahref="javascript:window.print()"rel="externalnofollow"target="_self">打印</a>
第二种方法:指定打印区域
把要打印的内容放入一个span或div,然后通过一个函数打印。
<spanid='div1'>把要打印的内容放这里</span> <p>所有内容</p> <divid="div2">div2的内容</div> <ahref="javascript:printme()"rel="externalnofollow"target="_self">打印</a> <scriptlanguage="javascript"> functionprintme() {document.body.innerHTML=document.getElementByIdx_x_x('div1').innerHTML+'<br/>'+document.getElementByIdx_x_x('div2').innerHTML; window.print(); } </script>
如果要打印的只是整个页面中的一小部分,就最好采用第二种方法。
第三种方法:如果要打印的页面排版和原web页面相差很大,采用此种方法。点打印按钮弹出新窗口,把需要打印的内容显示到新窗口中,在新窗口中调用window.print()方法,然后自动关闭新窗口。
window.print可以打印网页,但有时候我们只希望打印特定控件或内容,怎么办呢?
首先我们可以把要打印的内容放在div中,然后用下面的代码进行打印。
<html> <head> <scriptlanguage="javascript"> functionprintdiv(printpage) { varheadstr="<html><head><title></title></head><body>"; varfootstr="</body>"; varnewstr=document.all.item(printpage).innerHTML; varoldstr=document.body.innerHTML; document.body.innerHTML=headstr+newstr+footstr; window.print(); document.body.innerHTML=oldstr; returnfalse; } </script> <title>divprint</title> </head> <body> //HTMLPage //Othercontentyouwouldn'tliketoprint <inputname="b_print"type="button"class="ipt"onClick="printdiv('div_print');"value="Print"> <divid="div_print"> <h1style="Color:Red">TheDivcontentwhichyouwanttoprint</h1> </div> //Othercontentyouwouldn'tliketoprint //Othercontentyouwouldn'tliketoprint </body> </html>