zoukankan
html css js c++ java
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();
"
>
转载请注明出处[
http://samlin.cnblogs.com/
]
欢迎关注本人公众号:
作者赞赏
查看全文
相关阅读:
第五课 主引导程序的扩展 下
C.Candy
B.大钉骑马走江湖
A喝酒(北京林业大学校赛)
HDU 5666 Segment
南京理工大学第八届校赛题目题解(部分)
TCO 2016 Round 1B
139. Word Break
90. Subsets II
78. Subsets
原文地址:https://www.cnblogs.com/samlin/p/1151265.html
最新文章
[POI2012]A Horrible Poem
[POI2010]Beads
[CC-CHANOQ]Chef and odd queries
[XJOI-NOI2015-13-C]白黑树
[TJOI2016][HEOI2016]排序
基础高等数学
基础组合数学
基础数论
基础线性代数
基础多项式
热门文章
网络流24题
Linux文件IO与通用块层的请求合并
select 从应用层到内核实现解析
Linux文件系统之Mount流程分析
解析Linux中的VFS文件系统机制
TCP状态转化图 TIME_WAIT解析
第九课 主引导程序控制权的转移
第八课 突破512字节的限制--下
第七课 突破512字节限制--中
第六课 突破512字节的限制 上
Copyright © 2011-2022 走看看