在iframe的文档和/或shadow-root中注入html dom

时间:2018-04-23 02:04:18

标签: javascript jquery html iframe google-chrome-extension

我正在使用javascript(使用chrome扩展程序)将iframe注入网页。使用javascript,我正在创建iframe,我可以访问我的html网址,所以我可以使用$.get

来获取DOM
var elt = document.createElement('iframe');
elt.id = 'my_iframe';

$.get(chrome.extension.getURL('views/test.html'), function(doc) {

    var container = document.querySelector('#my_iframe');

    console.log(container.documentContent);  // can access
    console.log(container.shadowRoot); // can't access

    // ideally:
    container.shadowRoot($(doc));
    container.contentDocument($(doc));

});

document.getElementsByTagName('body')[0].appendChild(elt);

enter image description here

如何注入我的' text.html'在#shadow-root

原因是,当我使用elt.src = url时,它不会将html内容包装在#document#shadow-root中,这会导致错误 - (内容模糊) iframe未包含在#document#shadow-root - bug report

1 个答案:

答案 0 :(得分:4)

如果您只是更改iframe的内容,可以通过以下方式进行:

const iframe = document.querySelector('#myIframe')
iframe.outerHTML = '<iframe></iframe>' // clears the iframe
iframe.contentDocument.open()
iframe.contentDocument.write(yourHTMLText)
iframe.contentDocument.close()