我正在使用javascript(使用chrome扩展程序)将iframe注入网页。使用javascript,我正在创建iframe,我可以访问我的html网址,所以我可以使用$.get
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);
如何注入我的' text.html'在#shadow-root
?
原因是,当我使用elt.src = url
时,它不会将html内容包装在#document
或#shadow-root
中,这会导致错误 - (内容模糊) iframe未包含在#document
或#shadow-root
- bug report)
答案 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()