我想使用latest FLyingSaucer呈现PDF文档。
build.gradle:
implementation 'org.xhtmlrenderer:flying-saucer-pdf-openpdf:9.1.22'输入超文本标记语言文档(几乎是一个copy from W3 schools):
<!DOCTYPE html>
<html>
<head>
<style>
.flex-container {
display: flex;
background-color: DodgerBlue;
}
.flex-container > div {
background-color: #f1f1f1;
margin: 10px;
padding: 20px;
font-size: 30px;
}
</style>
</head>
<body>
<h1>Create a Flex Container</h1>
<div class="flex-container">
<div>1</div>
<div>2</div>
<div>3</div>
</div>
</body>
</html>示例代码(如JUnit测试):
class FlexTest {
@Test
void flexTest() throws FileNotFoundException, IOException {
final String htmlContent =
IOUtils.toString(new FileInputStream("input.html"), Charset.defaultCharset());
ITextRenderer renderer = new ITextRenderer();
renderer.setDocumentFromString(htmlContent);
renderer.layout();
renderer.createPDF(new FileOutputStream("output.pdf"));
}
}它工作正常,只是display: flex没有正确呈现。它看起来像是呈现为一个常规的<div>

FlyingSaucer/openpdf是否支持flex box?我没有发现任何说明它不是。
发布于 2021-11-08 15:34:33
飞碟不支持Flex,而且可能永远不会支持它。
飞碟支持的CSS仅限于CSS 2.1和大部分CSS paged media。
https://stackoverflow.com/questions/69882965
复制相似问题