- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个带有图表的网页,该图表的大小需要使用 CSS 固定为 width:1660px;height:480px;
。该页面(我可以链接到它吗?)在浏览器中正确显示,但在 Google Chrome 中打印时(我还没有测试过其他浏览器),它在水平方向上太大而无法放在一个页面中。如何缩放 HTML 以适合一个打印页面?
输出可能如下所示(Firefox 60):
我试过像这样搞乱媒体查询:
@media print
{
@page
{
size: 297mm 210mm; /* landscape */
/* you can also specify margins here: */
margin: 250mm;
margin-right: 450mm; /* for compatibility with both A4 and Letter */
}
}
但我在打印预览中看不到任何效果。
[编辑]
Internet Explorer 11 似乎能够在打印对话框中自动缩放页面。我不知道为什么谷歌浏览器也不能这样做。
[编辑]
我也尝试过转换页面。然而,Chrome 和 IE11 中的打印结果非常不同。
@media print
{
html
{
transform: scale(0.5);transform-origin: 0 0;
}
}
接下来,我尝试缩放页面。这工作得很好,但我不知道它是否只影响 Chrome,或者它是否也影响 IE 和 Firefox。
@media print
{
html
{
zoom: 50%;
}
}
无论哪种情况,用户都无法在使用 CSS 时禁用效果,除非您也创建新的 JavaScript 控件。
最佳答案
不幸的是,这是一个非常普遍的问题。根据我的经验,除了创建 PDF 之外,没有可靠的方法来控制浏览器的打印布局。有许多可用的“HTML 到 PDF”包,但虽然它们通常有效,但它们有类似的变化,具体取决于运行它们的浏览器。存在许多硬件问题(例如,屏幕尺寸)、浏览器设置(固有的浏览器之间的差异加上本地设置的默认字体大小和其他配置设置)和用户设置(例如页面缩放),恕我直言,除了生成服务器端文档外,这几乎是不可能的。
我敢肯定这不是您想听到的,但是确保用户能够按照您(开发人员)希望的方式打印网页的唯一可靠解决方案是 < strong>在服务器上生成完整的 PDF。这可以根据源语言(PHP、Python 等)使用许多不同的包来完成。这对开发人员来说肯定是更多的工作,但是您可以控制图像大小、文本大小、字体等 - 所有你应该能够用 CSS 控制的东西,并且知道页面将按预期打印。不要让页面上的打印按钮触发浏览器打印功能,而是让它从服务器下载页面文件,所有文件都已格式化并准备好打印。您可以定位字母(美国)或 A4(世界上大多数其他地方),这两种尺寸足够接近,大多数人可以在 Adobe Reader 或其他软件中进行调整以使其适合,而不会丢失数据或有太多空白。为了产生一致的输出,Google 文档和许多其他系统做完全相同的事情。
如果您的文档真的“只有一张图片”,那就更容易了。在服务器端创建图像并将其嵌入到单页可下载 PDF 中。如果您不能轻松地在服务器端创建图像,您可以使用诸如 URLBOX 之类的服务。 (我作为付费订阅者使用它,但我没有其他连接)生成图像并将它们下载到您的服务器以嵌入 PDF。
关于html - 打印时缩放 HTML 以适合一页,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50549663/
我正在制作一个简单的程序来更改我的计算机背景。我在网上发现了一个stackoverflow问题,或多或少涵盖了我想做的事情。我现在可以成功地将我的墙纸更改为平铺、居中和从在线图像 URL 拉伸(str
是的,这是另一个每组最大的问题之一!我已经尝试了几天,试图解决这个问题,但无济于事。我也一直在寻找,但我什至不知道我是否在正确的地方寻找。问题的最简化版本如下。 我有 2 个表,一个是多对多表,另一个
我想解析一些数据,我有一个 BNF 语法来解析它。谁能推荐任何能够生成可在移动设备上使用的代码的语法编译器? 由于这是针对 JavaME 的,因此生成的代码必须是: 希望很小 对外来 Java 库的依
我有一个动物园时间序列对象,vels : 2011-05-01 00:00:00 7.52 2011-05-01 00:10:00 7.69 2011-05-01 00:20:00 7.67 2011
我想创建一个供小型制造公司使用的生产管理系统。该系统将允许记录设备制造的不同阶段。要求如下: 1.非基于浏览器的界面。需要基于 Swing 或 AWT 的东西。虽然我了解实现基于浏览器的解决方案的便利
是否有任何 java 或 clojure 邮件库可以实现 lamson 的功能?特别是lamson的邮件路由功能非常酷http://verpa.wordpress.com/2010/11/13/mak
sklearn 中的 fit() 方法似乎在同一界面中服务于不同的目的。 应用于训练集时,像这样: model.fit(X_train, y_train) fit() 用于学习稍后将在测试集上使用 p
我使用 OSM 显示县的边界。它在大多数情况下工作得很好,但在某些情况下,县更大并且不适合 map 。 如何在开始渲染之前调整缩放级别? var map = L.map("mapCnty").setV
我正在致力于缩小和丑化我的 javascript 文件。我想知道合适的尺寸是多大。如果我将所有js文件合并成一个文件(经过缩小和丑化),它会大于1mb。我想,最好将它们分成 2-3 个文件(每个文件
我是 Java 新手。 我想在 GridPane 中放置一个 TextArea。我在过去几个小时内尝试了此操作,结果如下: 如您所见,TextArea 比我的 Gridpane 大得多。这是我的代码:
sklearn 中的 fit() 方法似乎在同一界面中服务于不同的目的。 应用于训练集时,像这样: model.fit(X_train, y_train) fit() 用于学习稍后将在测试集上使用 p
我认为这是一个基本问题,但也许我混淆了这些概念。 假设我使用 R forecast 包中的函数 auto.arima() 将 ARIMA 模型拟合到时间序列。该模型假设方差不变。我如何获得该方差?是残
我使用 OSM 显示县的边界。它在大多数情况下工作得很好,但在某些情况下,县更大并且不适合 map 。 如何在开始渲染之前调整缩放级别? var map = L.map("mapCnty").setV
我有一个很长的标签,这是我的第一个标签,我想把它放在我的单元格中。这就是我所拥有的,但它不起作用。 我有一个自定义的 UITabelviewCell ,里面有几个标签。 -(CGFloat)table
假设我有一个包含 WCS header 的 FITS 文件,这样我就可以执行以下操作: #import healpy as hp #import astropy.io.fits as pyfits #
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭10 年前。 Improve
我们正在构建一个与其他系统有多个集成接触点的应用程序。我们有效地使用 Unity 来满足我们所有的依赖注入(inject)需求。整个业务层是用接口(interface)驱动的方法构建的,实际实现在应用
我得到了 MKMapView 和一些注释。我使用下一个代码来显示所有注释: NSArray *coordinates = [self.mapView valueForKeyPath:@"annotat
我在一家托管公司工作,我们经常收到安装、新域、滞后修复等方面的请求。为了大致了解仍然开放的内容,我决定制作一个非常简单的票务系统。我有一点 php 知识和一点 MySQL 知识。目前,我们将根据客户的
我想向我的 UITableView 添加背景图像,它适合 UI,还具有导航 Controller 和工具栏。在那种情况下,我没有找到适合 iPhone 和 iPad 不同屏幕的 tableview 的
我是一名优秀的程序员,十分优秀!