关于html打印或者转word文档分页问题

最近有人私信 问xh-htmlword插件能不能支持分页,

其实word文档要识别分页需要 标签里填有 page-break-before: always属性字段

 <div style="page-break-before: always" ></div>
//无效的话 使用下面这个
 <span><br clear="all" style="page-break-before: always" /> </span>

 然后发现坑来了 ,分页没有效果,原来是 浏览器编译后 自动将page-break-before: always

转成了break-before: page,应该是兼容问题导致的 

所以要让浏览器有效识别到的话 需要在转出字符的时候全局替换回来

 //content 是读取后的 明白字符串 
 content = content.replace(/break-before: page/g, `page-break-before: always`);

直接全局替换即可分页,亲测有效,如果不想麻烦 直接使用 我封装的xh-htmlword插件一键导出就行了,直接在需要的地方 加上<span><br clear="all" style="page-break-before: always" /> </span> 这句话

  • 13
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
要在使用Apache POI将HTML换为Word时实现分页和目录,您需要进行以下步骤: 1. 将HTML内容换为XWPFDocument对象。这可以使用POI的org.apache.poi.xwpf.converter.core.HtmlConverter类中的convert()方法来实现。 2. 在XWPFDocument对象中每页之间添加分页符。这可以通过在XWPFDocument对象中创建新的XWPFParagraph对象,并将其设置为分页符样式来实现。以下是一个示例代码: ``` // 创建一个段落并设置为分页符 XWPFParagraph paragraph = document.createParagraph(); paragraph.setPageBreak(true); ``` 3. 在XWPFDocument对象中添加目录。这可以通过使用XWPFDocument对象的createTOC()方法来实现。以下是一个示例代码: ``` // 创建目录 document.createTOC(); ``` 请注意,必须在文档的某个位置调用createTOC()方法才能生成目录。如果您希望在文档的特定位置创建目录,请将其放置在相应的位置。 完整的代码示例: ``` import java.io.*; import org.apache.poi.xwpf.converter.core.*; import org.apache.poi.xwpf.converter.xhtml.*; import org.apache.poi.xwpf.usermodel.*; public class HtmlToWordExample { public static void main(String[] args) throws Exception { // 读取HTML文件内容 String html = readHtml("example.html"); // 将HTML换为XWPFDocument对象 XWPFDocument document = new XWPFDocument(); XHTMLImporterImpl importer = new XHTMLImporterImpl(document); importer.setRunDirection(PDF_RUN_DIRECTION.RTL); importer.importDocument(new ByteArrayInputStream(html.getBytes()), null); // 在每页之间添加分页符 for (XWPFParagraph paragraph : document.getParagraphs()) { paragraph.setPageBreak(true); } // 创建目录 document.createTOC(); // 将文档保存到文件 FileOutputStream out = new FileOutputStream("example.docx"); document.write(out); out.close(); document.close(); } private static String readHtml(String filename) throws IOException { BufferedReader reader = new BufferedReader(new FileReader(filename)); StringBuilder builder = new StringBuilder(); String line; while ((line = reader.readLine()) != null) { builder.append(line); } reader.close(); return builder.toString(); } } ``` 这个示例代码将读取名为“example.html”的HTML文件,并将其换为带有分页符和目录的Word文档。请注意,您需要在类路径中包含POI和POI OOXML依赖项才能运行此代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值