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 表单时,动态修改内容无法生效该如何解决?的详细内容,更多请关注其它相关文章!