登录
首页 >  文章 >  前端

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

时间:2024-11-16 21:19:09 188浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《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 表单时,动态修改内容无法生效该如何解决? 》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>