微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从JS设置打印首选项

如何解决从JS设置打印首选项

| 所以...从我在Google上可以找到的东西,我找不到使用Javascript设置打印首选项(阅读方法:边距,方向,页脚等)的方法。 我要告诉老板他想做的事是不可能的。我想检查一下您是否会在此之前做好事。请告诉我。 我发现在FF中,您可以使用一些user_pref(key,val)设置来设置用户的偏好设置,但这不适用于90%以上的用户。我正在寻找可以涵盖IE \(尽可能多),FF和Chrome的产品。 谢谢忍者们的回覆。     

解决方法

        所以...经过一整天的观察,我认为我找到了自己问题的答案。简而言之,答案是JS和/或CSS将不允许您覆盖客户端浏览器的默认页面设置。 这是我尝试过的。如果您创建一个带有空头的简单HTML文件,并且仅包含文本“ Test”的正文,您将能够看到我测试的内容。 打印样式表不能解决您的问题。将正文上的页边距设置为0px 0px 0px 0px与单击“文件”>“页面设置”并将所有页边距设置为0是不同的。自己尝试一下。这就是为什么打印样式表不能解决您的问题。 JS无法解决您的问题。如果您访问的每个页面都修改了本地JS属性,您是否可以成像?允许每个页面访问您的本地打印设置将违反安全性,并且不允许这样做。因此,JS无法解决您的问题。 我希望有人在这里做出回应,让我知道我错了。否则...这很烂...并且需要发生。我有很多老用户...让他们在页面设置中设置边距是一件很痛苦的事情。另外,客户也不想我们重构页面,这样他们就不需要。我介于一块石头和一块硬石之间。     ,        您可以使用CSS设置页面方向和边距:
@page {
   size: landscape;
   margin: 10%
}
您还可以使用
<tfoot>
元素在每页底部设置页脚。 编辑:正如比雅明所指出的,这是一间中途的房子。您无法真正更改打印机首选项(单击“打印”时出现在“打印对话框”中的首选项)。另外,IE严重缺乏对
@page
选择器的支持((四处看看IE9是否支持它并且找不到任何东西))。作为替代方案,您始终可以尝试将其应用于打印样式表中的正文。
body {
   size: landscape;
   margin: 10%
}
虽然我不知道该怎么做。     ,        我认为您很难在HTML和CSS中做到这一点。问题的很大一部分是打印机的页边距都是特定于打印机类型的:大多数打印机都有可以设置的最小页边距(等于他们需要抓住页面的空间以及打印头的左右移动)。 可接受的边距也会根据纸张尺寸而有所不同(在较小的纸张上,边距通常会小于打印机可接受的最大边距)。例如,如果将A5纸张装入A4打印机,则可以设置的边距将不同于装入A4的页边距。 这些信息都无法通过CSS,javascript或其他方式提供给网页。 现在,就解决方案而言,PDF文件确实允许您在文件中嵌入一些打印机默认设置-Acrobat Pro将允许您指定缩放选项,默认份数等。我不介意打赌还有Acrobat不公开的文件格式中更多可用的设置。 无论您使用哪种服务器端技术,都有许多功能齐全的PDF生成工具。好的甚至可以允许您提供URL,并将HTML + CSS呈现为PDF内容-在某种程度上可以自动生成。不过,PDF的生成会占用大量CPU,并且对用户也不是无缝的(大多数浏览器都需要PDF插件)。 我知道这并不理想,但这是我要研究的途径。祝好运!     ,        使用CSS将帮助您实现这一目标。
@page {
  margin:0cm;
}
    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。