JS 打印 HTML 表单时,动态修改内容无法生效该如何解决?

JS 打印 HTML 表单时,动态修改内容无法生效该如何解决?

在使用 js 打印 html 表单时,内容更新后如果部分内容未生效,可能是因为使用了错误的方法获取 dom 元素的 html

具体问题在于,使用 prop("outerHTML") 方法获取的元素 HTML 代码包含了元素本身及其子元素,但如果直接将此代码作为打印的内容,则无法获取到动态修改后的值。

要解决这个问题,需要使用 cloneNode 方法复制一份原始 DOM 元素,然后将复制的元素添加到打印框架中。这样,打印时就可以获取到修改后的值了。

以下代码演示了如何通过 cloneNode 方法解决问题:

$('#print-iframe').remove(); // 每次打印前移除先前生成的元素
// 开始打印
let iframe1 = document.createElement('IFRAME');
let doc1 = null;
iframe1.setAttribute('id', 'print-iframe');
iframe1.setAttribute('style', 'position:absolute;width:0px;height:0px;left:-0px;top:-0px;visibility: auto;');
document.body.appendChild(iframe1);
setTimeout(function () {
  doc1 = iframe1.contentWindow.document;
  doc1.body.appendChild(document.querySelector('#divKanZhengPanel-binli').cloneNode(true));
  doc1.close();
  iframe1.contentWindow.focus();
  iframe1.contentWindow.print();
});

使用 cloneNode 方法后,打印时将显示修改后的表单内容,包括 textarea 内容和选中的复选框。

以上就是JS 打印 HTML 表单时,动态修改内容无法生效该如何解决?的详细内容,更多请关注其它相关文章!