JS实现局部打印和预览

简介:

第一种:

 

JS 实现简单的页面局部打印 
function  preview(oper)
...
{
if (oper < 10)...{
bdhtml
=window.document.body.innerHTML;//获取当前页的html代码
sprnstr="<!--startprint"+oper+"-->";//设置打印开始区域
eprnstr="<!--endprint"+oper+"-->";//设置打印结束区域
prnhtml=bdhtml.substring(bdhtml.indexOf(sprnstr)+18); //从开始代码向后取html

prnhtml
=prnhtml.substring(0,prnhtml.indexOf(eprnstr));//从结束代码向前取html
window.document.body.innerHTML=prnhtml;
window.print();
window.document.body.innerHTML
=bdhtml;


}
 else ...{
window.print();
}


}


使用很简单 将页面内要打印的内容加入中间
<!-- startprint1 --> XXXXX <!-- endprint1 -->
再加个打印按纽 onclick
= preview( 1

 

第二中:组件法

 

 

WebBrowser是IE内置的浏览器控件,无需用户下载.

一、WebBrowser控件 
  
< object ID = ' WebBrowser '  WIDTH = 0  HEIGHT = 0  CLASSID = ' CLSID:8856F961-340A-11D0-A96B-00C04FD705A2 ' ></ object >  
二、WebBrowder控件的方法 
// 打印 

WebBrowser1.ExecWB(
6 , 1 ); 

// 打印设置 

WebBrowser1.ExecWB(
8 , 1 ); 

// 打印预览 

WebBrowser1.ExecWB(
7 , 1 ); 

关于这个组件还有其他的用法,列举如下: 
WebBrowser.ExecWB(
1 , 1 ) 打开 
Web.ExecWB(
2 , 1 ) 关闭现在所有的IE窗口,并打开一个新窗口 
Web.ExecWB(
4 , 1 ) 保存网页 
Web.ExecWB(
6 , 1 ) 打印 
Web.ExecWB(
7 , 1 ) 打印预览 
Web.ExecWB(
8 , 1 ) 打印页面设置 
Web.ExecWB(
10 , 1 ) 查看页面属性 
Web.ExecWB(
15 , 1 ) 好像是撤销,有待确认 
Web.ExecWB(
17 , 1 ) 全选 
Web.ExecWB(
22 , 1 ) 刷新 
Web.ExecWB(
45 , 1 ) 关闭窗体无提示 
但是打印是会把整个页面都打印出来的,页面里面有什么东西就打印出来,我们有时候只需要打印数据表格,这时我们就要写一个样式了:把不想打印的部份隐藏起来:
样式内容:
< style type = " text/css "  media = print >
.noprint...
{display : none }
</ style >
然后使用样式就可以:
< p class = " noprint " > 不需要打印的地方 </ p >

代码如下:

< script language = " javascript " >  
function  printsetup()...
// 打印页面设置 
wb.execwb(8,1); 
}
 
function  printpreview()...
// 打印页面预览 

wb.execwb(
7,1); 

}
 

function  printit() 
...

if (confirm('确定打印吗?')) ...
wb.execwb(
6,6
}
 
}
 
</ script >  

< OBJECT classid = " CLSID:8856F961-340A-11D0-A96B-00C04FD705A2 "  height = 0  id = wb name = wb width = 0 ></ OBJECT >  
< input type = button name = button_print value = " 打印 "  class = " noprint "  onclick = " javascript:printit() " >  
< input type = button name = button_setup value = " 打印页面设置 "  class = " noprint "  onclick = " javascript:printsetup(); " >  
< input type = button name = button_show value = " 打印预览 "  class = " noprint "  onclick = " javascript:printpreview(); " >  




本文转自Sam Lin博客园博客,原文链接:http://www.cnblogs.com/samlin/archive/2008/04/13/1151265.html,如需转载请自行联系原作者

目录
相关文章
|
26天前
|
JavaScript 前端开发
js开发:请解释什么是作用域(scope),并说明全局作用域、局部作用域和块级作用域的区别。
JavaScript中的作用域规定了变量和函数的可见性与生命周期。全局作用域适用于整个脚本,变量可通过全局对象访问,可能导致命名冲突和内存占用。局部作用域限于函数内部,每次调用创建新作用域,执行完毕后销毁。ES6引入的块级作用域通过`let`和`const`实现,变量仅在其代码块内有效,并有暂时性死区。作用域机制有助于代码组织和变量管理。
23 1
|
3月前
|
JavaScript
JS作用域(全局作用域+局部作用域)
JS作用域(全局作用域+局部作用域)
14 0
|
7月前
|
JavaScript
js上传图片本地预览(整理)
js上传图片本地预览(整理)
|
5月前
|
JavaScript 前端开发
前端js上传照片实现可预览功能
前端js上传照片实现可预览功能
31 0
|
11月前
|
JavaScript Java
Vue+JS+layUI 完成预览模式功能
Vue+JS+layUI 完成预览模式功能
|
JavaScript
原生 js 实现截图粘贴预览图片功能
原生 js 实现截图粘贴预览图片功能
121 0
原生 js 实现截图粘贴预览图片功能
|
JavaScript
js基础笔记学习86-全局和局部作用域
js基础笔记学习86-全局和局部作用域
50 0
js基础笔记学习86-全局和局部作用域
|
JavaScript 前端开发
利用JavaScript实现二级联动
利用JavaScript实现二级联动 要实现JavaScript二级联动效果,首先要确定需要哪些技术: 二维数组 for in循环 new Option(text,value,true,true) add(option,null) onchange() 表单事件 HTML代码: &lt;!-- &lt;input type=&quot;text&quot; id=&quot;text&quot;&gt; --&gt; 请选择省份: &lt;select name=&quot;&quot; id=&quot;provinces&quot;&gt; &lt;!-- &lt;option value=&quot;江苏省&quot;&gt;江苏省&lt;/option&gt;
|
JavaScript 前端开发
JavaScript函数柯里化的实现原理,进来教你完成一个自己的自动实现柯里化方法
JavaScript函数柯里化的实现原理,进来教你完成一个自己的自动实现柯里化方法
167 0
|
移动开发 JavaScript weex
weex-自定义module,实现weex在iOS的本地化,js之间互相跳转,交互,传值(iOS接入weex的最佳方式)
weex-自定义module,实现weex在iOS的本地化,js之间互相跳转,交互,传值(iOS接入weex的最佳方式)
219 0