在他们的网站上调试 jquery 代码时(通过 chrome 开发者工具栏)
我注意到他们的例子如下Iframe
:
这里 - 例如有一个样本在 Iframe 下,但经过调查,我发现 Iframe 没有SRC
图片说明了一切
问题 :
是否可以在不设置 SRC 的情况下将内容设置为 iframe ?
ps 这个菜单也显示了一个空的内容
是的,可以加载一个空的<iframe>
(没有src
指定),然后使用脚本将内容应用到它。
请参阅:http ://api.jquery.com/jquery-wp-content/themes/jquery/js/main.js (第 54 行及以下)。
或者干脆尝试:
<iframe></iframe>
<script>
document.querySelector('iframe')
.contentDocument.write("<h1>Injected from parent frame</h1>")
</script>
是的,这是使用 jQuery 更改 iframe 的 html 的方法
var context = $('iframe')[0].contentWindow.document,
$body = $('body', context);
$body.html('Cool');
演示:http: //jsfiddle.net/yBmBa/
document.contentWindow:https://developer.mozilla.org/en-US/d...
看起来这是跨浏览器最兼容的解决方案,也被W3C认可
<iframe src="about:blank"></iframe>
当然。您可以通过以下方式获得对iframe
'sdocument
对象的引用
var doc = iframe.contentDocument;
然后您可以像在当前文档中一样创建和添加元素。
如果 iframe 没有src
属性,它仍然会包含一个空文档。我相信尽管至少较旧的 IE 版本需要设置src
属性,否则 iframe 将没有文档。
另请参阅:iframe 的 contentDocument。
尝试给予:
src ="javascript:false;"
有允许直接设置 HTML 内容的srcdoc
属性:iframe
<iframe srcdoc="<p>Hello world!</p>" src="demo_iframe_srcdoc.htm"></iframe>
src
用于备份,以防浏览器不支持srcdoc
。
试试看。
HTML
<div id="iframecontent" style="display: none;">
<b>Hello World!</b> <br /> <i>Hello Again !</i>
</div>
<div style="margin: auto; width: 80%;">
<iframe height="100" width="100%" src="about:blank" name="myiframe"
id="myiframeid"> </iframe>
<br />
<button id="tryIt" onclick="onTryItClick()">Try It</button>
</div>
JavaScript:
<script type="text/javascript">
function onTryItClick() {
var content = document.getElementById("iframecontent").innerHTML;
var iframe = document.getElementById("myiframeid");
var frameDoc = iframe.document;
if (iframe.contentWindow)
frameDoc = iframe.contentWindow.document;
frameDoc.open();
frameDoc.writeln(content);
frameDoc.close();
}
</script>
参考: http ://duleekag.blogspot.com/2014/01/html-iframe-without-src-attribute.html
您甚至可以使用数据 uri 作为 src:
<!-- a zero width space -->
<iframe src="data:text/plain;charset=utf-8;base64,4oCL"></iframe>
<!-- Hello World! -->
<iframe src="data:text/plain;charset=utf-8;base64,SGVsbG8gV29ybGQh"></iframe>
将 javascript 和 jQuery 中的最佳答案混合在一起,我为iframe
页面中的每个问题提出了这个解决方案:
<div class="iframewrapper ws-s-top mb-50" data-content="<!DOCTYPE html><html><head></head><body><p>Hello world</p></body></html>">
<iframe frameborder="0" src=""></iframe>
</div>
$(".iframewrapper").each(function(){
var html = $(this).attr("data-content");
var iframe = $(this).find('iframe');
var context = iframe[0].contentDocument.write(html);
iframe[0].contentWindow.document.close(); //without this line, page loading animations won't go away!
});