Js打印样式设置

本文详细介绍了如何使用CSS样式进行网页打印,包括创建打印样式文件、利用WebBrowser控件实现打印功能、配置页眉页脚以及选择性打印内容等关键步骤。通过实例演示,帮助开发者轻松实现网页的高效打印。

浏览器自带打印功能(或手动设置启用ActiveX控件)。书写有不足或描述不清的地方请大家指正。^-^

利用CSS样式打印是经常使用的一种打印方法,利用它可以非常方便的实现打印页面中的指定内容和分页打印,下面将通过具体实例介绍如何利用CSS样式打印。

[分析]:
1.打印样式区分:打印网页带页面样式,需指明一个media='print'的样式,建议分开,如下创建军一个bankprint.css打印样式文件。
<link rel="stylesheet" media="screen" type="text/css" href="/public/default/css/bank.css" />
<!-- 打印样式 -->
<link rel="stylesheet" media="print" type="text/css" href="/public/default/css/bankprint.css" />
例:
<style media=‘print’>

.Noprint {display:none;}

.PageBreak {page-break-after: always;}

</style>
说明:
media类型是CSS属性媒体类型,用于直接引入媒体的属性。其语法格式如下:
@media screen | print | projection | braille | aural | tv | handheld | all
参数说明
screen:指计算机屏幕。
print:指用于打印机的不透明介质。
projection:指用于显示的项目。
braille:盲文系统,指有触觉效果的印刷品。
aural:指语音电子合成器。
tv:电视类型的媒体。
handheld:指手持式显示设备。
all:用于所有媒体。

2.WebBrowser控件

同其他控件一样,首先我们需要在页面中嵌入WebBrowser控件,不过由于该控件是IE浏览器自带的,支持浏览器默认安全设置,因此避免了安全性设置的麻烦。对于IE7及以上安全性要求更高的浏览器,您或许还是需要自定义IE的安全性级别。
<OBJECT classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2" id="wb" width="0" height="0"></OBJECT>
下面就是该控件涉及打印的功能调用,用户可以在JavaScrip中调用:
wb.execwb(6,1); //打印,打印当前页面
wb.execwb(7,1); //打印预览
wb.execwb(8,1); //打印设置,调出系统打印设置对话框


3.页眉、页脚设置:打印时,有的需要去掉页眉页脚,或替换成自已想要的。
<script language="JavaScript">

var hkey_root,hkey_path,hkey_key;
hkey_root="HKEY_CURRENT_USER";
hkey_path="\\Software\\Microsoft\\Internet Explorer\\PageSetup\\";
//配置网页打印的页眉页脚为空
function pagesetup_null(){
try{
var RegWsh = new ActiveXObject("WScript.Shell");
hkey_key="header";
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
hkey_key="footer";
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
//&b 第&p页/共&P页 &b
}catch(e){}
}
//配置网页打印的页眉页脚为默认值
function pagesetup_default(){
try{
var RegWsh = new ActiveXObject("WScript.Shell");
hkey_key="header";
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&w&b页码,&p/&P")
hkey_key="footer";
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&u&b&d");
}catch(e){}
}
...
</script>

[源码例子]:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>打印设置</title>
<link rel="stylesheet" media="screen" type="text/css" href="http://www.chinasvf.com/Webs/public/default/css/bank.css" />
<!-- 打印样式 -->
<link rel="stylesheet" media="print" type="text/css" href="http://www.chinasvf.com/Webs/public/default/css/bankprint.css" />
<script language="JavaScript">
var hkey_root,hkey_path,hkey_key;
hkey_root="HKEY_CURRENT_USER";
hkey_path="\\Software\\Microsoft\\Internet Explorer\\PageSetup\\";
//配置网页打印的页眉页脚为空
function pagesetup_null(){
try{
var RegWsh = new ActiveXObject("WScript.Shell");
hkey_key="header";
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
hkey_key="footer";
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
//&b 第&p页/共&P页 &b
}catch(e){}
}
//配置网页打印的页眉页脚为默认值
function pagesetup_default(){
try{
var RegWsh = new ActiveXObject("WScript.Shell");
hkey_key="header";
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&w&b页码,&p/&P")
hkey_key="footer";
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&u&b&d");
}catch(e){}
}
//打印选区内容
function doPrint() {
pagesetup_null();
bdhtml=window.document.body.innerHTML;
sprnstr="<!--startprint-->";
eprnstr="<!--endprint-->";
prnhtml=bdhtml.substr(bdhtml.indexOf(sprnstr)+17);
prnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr));
window.document.body.innerHTML=prnhtml;
window.print();
}
//打印页面预览
function printpreview(){
pagesetup_null();
//wb.printing.header = "居左显示&b居中显示&b居右显示页码,第&p页/共&P页";
//wb.printing.footer = "居左显示&b居中显示&b居右显示页码,第&p页/共&P页";
try{
wb.execwb(7,1);
}catch(e){
alert("您的浏览器不支持此功能,请选择'文件'->'打印预览'");
}
}
//打印
function prints(){
pagesetup_null();
//wb.printing.header = "居左显示&b居中显示&b居右显示页码,第&p页/共&P页";
//wb.printing.footer = "居左显示&b居中显示&b居右显示页码,第&p页/共&P页";
try{
wb.execwb(6,1);
}catch(e){
alert("您的浏览器不支持此功能");
}
}
</script>
</head>
<body>
<OBJECT classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2" id="wb" width="0" height="0"></OBJECT>
<div id="bankwrap">
<div class="Noprint"><a href="http://www.chinasvf.com" style="cursor:pointer; color:#0000FF">返回首页</a></div>
<div style="text-align:right">
<p class="Noprint">
<span style="cursor:pointer; color:#0000FF" onclick="javascript:window.open('http://www.chinasvf.com/Webs/Share/printhelp')" class="Noprint">打印帮助</span>
<span style="cursor:pointer; color:#0000FF" onclick="printpreview();">打印预览</span>
<span style="cursor:pointer; color:#0000FF" onclick="prints();" class="Noprint">打印</span>
</p>
</div>
<div class="banktitle">内容</div>
</div>
</body>
</html>

相关1:網頁打印代碼大全

2.http://topic.youkuaiyun.com/t/20050228/17/3812979.html

<think>好的,我现在需要帮助用户解决如何在Print.js设置打印样式的间距问题。首先,我需要回顾一下用户提供的引用内容,看看是否有相关的信息。 根据引用[4],用户提到在Vue中使用PrintJS时,边距设置调整后感觉不对,但其他组件也没解决问题。这说明用户可能遇到了默认样式覆盖的问题。而引用[2]中提到,解决字体大小设置的问题是通过传入无效的font_size值来避免默认样式干扰。这可能暗示着类似的方法可以用于边距设置。 接下来,我需要考虑Print.js的配置选项。根据引用[3],使用jquery.print.js时,可以设置globalStyles和mediaPrint来控制样式的应用。可能PrintJS也有类似的参数,比如是否加载外部CSS或媒体查询。 用户的问题是关于边距,所以应该关注CSS中的margin属性。通常,打印样式可以通过@media print媒体查询来定义,但可能需要覆盖PrintJS的默认设置。例如,在打印样式中添加如下代码: @media print { @page { margin: 2cm; /* 调整页边距 */ } body { margin: 0; /* 确保内容区域无额外边距 */ } } 此外,PrintJS的配置中可能需要禁用默认样式,如设置css参数为空,并手动添加自定义样式。例如,在调用printJS时,传入style参数或引入自定义的CSS文件。 另外,引用[2]提到通过传入无效的font_size值来避免默认样式的影响,这可能适用于边距设置,但需要测试。或者,可以尝试在style参数中直接写入内联样式,使用!important覆盖原有设置。 总结步骤: 1. 使用@media print定义页边距。 2. 在PrintJS配置中禁用默认样式,如设置globalStyles为false。 3. 通过style参数或自定义CSS添加边距样式。 4. 检查是否其他CSS影响了打印区域,可能需要更具体的选择器或!important。 需要确保用户正确应用了这些步骤,并提供代码示例。同时,提醒用户注意浏览器默认的页边距设置可能影响效果,建议在打印预览中调整。</think>在Print.js设置打印样式的间距,可通过以下方法实现: ### 一、通过CSS媒体查询设置页边距 在全局CSS中添加: ```css @media print { @page { margin: 2cm; /* 上下左右统一间距 */ margin-top: 3cm; /* 单独设置顶部间距 */ } body { margin: 0 !important; /* 消除默认边距 */ } .print-area { padding: 20px; /* 内容区域间距 */ } } ``` ### 二、Print.js配置参数调整 ```javascript printJS({ printable: 'elementId', type: 'html', css: '', // 禁用默认CSS加载 style: '@page { margin: 2cm; } .content { padding: 15mm; }', // 直接注入样式 scanStyles: false, // 关闭自动扫描样式 font_size: 'invalidValue', // 规避默认字体限制[^2] honorMarginPadding: true // 启用边距继承 }); ``` ### 三、注意事项 1. 使用`!important`覆盖默认样式: ```css @media print { .custom-margin { margin: 30px 0 !important; } } ``` 2. 若使用Vue框架,建议在打印容器元素上直接添加行内样式: ```html <div id="printBox" style="margin: 20mm; padding: 10mm"> <!-- 打印内容 --> </div> ``` 3. 浏览器兼容性处理:不同浏览器对@page规则支持度不同,建议通过打印预览测试效果 ### 四、完整示例 ```javascript // 打印函数调用 printJS({ printable: 'printContent', type: 'html', style: '@page { margin: 1in; } #printContent { padding: 20px; }', scanStyles: false, css: ['/static/print-styles.css'], // 自定义CSS文件 font_size: '12pt' // 兼容性设置[^2] }); ``` [^1]: 引用[4]指出PrintJS的默认边距设置可能受浏览器默认样式影响,建议强制覆盖 : 引用[2]的字体大小解决方案同样适用于边距设置,通过干扰默认样式实现自定义 [^3]: 引用[3]说明禁用全局样式(globalStyles: false)可避免样式污染
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值