免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1159 | 回复: 0
打印 上一主题 下一主题

JavaScript打印和预览等 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-21 17:17 |只看该作者 |倒序浏览

               
1.JavaScript局部打印
可以用样式控制,你想让那块打印就打印啊,样式如下:
[color="#0000ff"]
.noprint{display : none }

然后使用样式就可以:
[color="#ff0000"]不需要打印的地方
=============================================================
2:组件法

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();">
3:

JS 实现简单的页面局部打印

function preview(oper)


......{


if (oper  10)......{

bdhtml=window.document.body.innerHTML;//获取当前页的html代码

sprnstr=""+oper+"-->";//设置打印开始区域

eprnstr=""+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-->XXXXXendprint1-->

再加个打印按纽 onclick=preview(1)


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/26845/showart_1087849.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP