JavaScript和CSS能否控制浏览器打印设置的页眉页脚?
许多开发者希望利用JavaScript或CSS来控制浏览器打印对话框中的页眉页脚设置,例如默认取消勾选或自定义页眉页脚内容。然而,这并非易事,本文将深入探讨其可行性及局限性。
问题概述
目标是通过代码控制浏览器打印设置中的页眉页脚选项,具体要求:
- 默认禁用页眉页脚: 打印时默认不显示页眉页脚。
-
使用
@media print
自定义页眉页脚: 使用@media print
样式规则自定义页眉页脚内容,但此方法在使用printJS
插件时无效。
用户提供的代码片段如下:
html2canvas(this.$refs.templateToImg, { backgroundColor: null, useCORS: true, windowHeight: document.body.scrollHeight, }).then(canvas => { dom.style.height = 'calc(100vh - 400px)' dom.style.overflow = 'auto' const url = canvas.toDataURL('image/jpg') this.img = url const styles = "@media print { @page {height: 100%;@top-left {content: '页首内容';}@bottom-center {content: '页脚内容';}}}" printJS({ printable: url, type: 'image', documentTitle: this.previewTitle(), style: styles, onLoadingEnd: () => { this.printLoading = false dom.style.height = 'auto' dom.style.overflow = 'visible' } }) })
解决方案与限制
关键在于理解以下几点:
- 浏览器打印设置的不可控性: 浏览器打印设置(包括页眉页脚)由浏览器本身或操作系统控制,JavaScript和CSS无法直接干预。
-
@media print
的局限性:@media print
可控制打印样式,但不能直接修改浏览器打印设置。printJS
插件可能忽略通过@media print
设置的样式。 -
printJS
插件的特性:printJS
主要用于打印HTML内容或图片,不支持直接修改浏览器打印设置。 代码中尝试通过style
参数传递@media print
样式,但在printJS
中效果不佳。
因此,结论是:JavaScript和CSS无法直接控制浏览器打印设置的页眉页脚选项。 这属于浏览器和操作系统的权限范围。
要自定义页眉页脚,只能在打印内容中直接添加这些元素,并确保它们在打印时可见且不受打印插件影响。 开发者需要放弃直接控制浏览器打印设置的想法,转而关注在打印内容本身中实现页眉页脚的定制。
以上是如何通过JavaScript或CSS控制浏览器打印设置中的页首和页尾?的详细内容。更多信息请关注PHP中文网其他相关文章!

当他们在2013年去Chrome时,我们失去了歌剧。与Edge今年早些时候也进行了同样的交易。迈克·泰勒(Mike Taylor)称这些变化为“减少

在本周的综述中,Apple进入Web组件,Instagram如何插入脚本以及一些思考的食物,以进行自托管关键资源。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

Dreamweaver CS6
视觉化网页开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。