
在使用 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 表单时,动态修改内容无法生效该如何解决?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1558882.html
微信扫一扫
支付宝扫一扫