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();
"
>
查看全文
相关阅读:
Linux学习笔记六----------文件传输
Linux学习笔记五----------文本编辑
Linux学习笔记四----------远程连接和SSH
Linux学习笔记三----------Linux进阶知识和命令
Linux学习笔记二----------Linux基础知识和命令
ArcGIS API for JavaScript3.16 使用中遇到的问题,及解决方法
ArcGIS API for JavaScript学习
echarts容器动态变化高度
好用的流程图js插件
jeecg-boot + ant-design-vue开发,希望点击菜单打开新窗口页签
原文地址:https://www.cnblogs.com/xsmhero/p/2360853.html
最新文章
windows7 64位系统安装CPU版本TensorFlow(anaconda3.6)
TensorFlow:检查显卡支持哪个版本的CUDA
mnist的格式说明,以及在python3.x和python 2.x读取mnist数据集的不同
在Django中运行ExtJS 事例
python 2.7 pip导入django,将python部署到sublime上
django1.4 简单事例 ,根目录下templates
好久没更新过了
近半年所踩的坑的总结
CentOS上安装Hadoop2.7,添加数据节点,运行wordcount
在SCIKIT中做PCA 逆变换 -- 新旧特征转换
热门文章
特征工程之应用业务知识(保险)
随机森林
决策树
ORA-00911: invalid character --- 字符集的问题
足球游戏论坛数据分析--简单粗暴的K均值聚类
深入理解计算机系统之存储器层次结构学习笔记
Linux学习笔记十一----------内存和磁盘管理
Linux学习笔记十----------安装MariaDB数据库
Linux学习笔记九----------管理服务器和服务
Linux学习笔记八----------Shell实现图片展示网页
Copyright © 2011-2022 走看看