所以我正在创建一个小部件,从客户端提取一些文本,将其发送回服务器进行处理,并将iframe嵌入到客户端。但是,如果出现任何错误,我的客户希望我完全隐藏/删除iframe,而不是生成自定义错误页面。我想知道实现这一目标的最佳途径是什么。这是我给客户的脚本:
<script type="text/javascript">
$(document).ready(function(){
if($(".single-post").length===1)
{
heading =$('.post h2').text();
heading =heading.trim();
link = $('.post h2 a').attr('href');
date = $('.post .meta .timr').text()
if($('div .entry p').text()!="")
para_full = $('div .entry p').text()
total_length = para_full.length;
if (total_length<3000)
{
text_send = para_full;
}
else{
tsstart = (total_length/2) - 250;
tsend = (total_length/2) + 250;
text_send = para_full.substring(tsstart,tsend );
}
if($('div .entry img')[0].src !="" && $('div .entry img')[0].src != "undefined")
image_url = $('div .entry img')[0].src
if($('h3#comments').text()!="" && $('h3#comments').text()!="undefined")
{
no_of_comments = $('h3#comments').text()
l = no_of_comments.indexOf('Responses');
no_of_comments = no_of_comments.substring(0,l-1)
}
else
{
no_of_comments=0;
}
$(".client_site_iframe").attr("src","http://mydomain.com/query?"+"&searchtext="+text_send+"&link="+link+"&imagelink="+image_url+"&heading="+heading+"&date="+date+"&full_text="+para_full);
}
})
</script>
<div class="client_site_container">
<iframe class="client_site_iframe" id="mysite_iframe" width="650px" height="205px" frameborder="no" scrolling="no"></iframe>
</div>
我尝试的解决方案之一是编写错误处理函数
myHandler = function(error) {
document.getElementById('client_site_iframe').style.display = 'none';
}
将在以下条件下触发
<script>
if ($("#client_site_iframe html body").text().length === '')
{myHandler();}
</script>
但由于相同的原始策略,这不起作用。实际上,我无法在客户端使用jQuery访问iframe中生成的任何HTML元素。我想知道是否有更好的方法来实现这一点,我对客户端脚本非常陌生,所以我不确定这个问题是否可以解决,或者是否有人推荐使用AJAX请求,但我不知道如何这将有助于我解决原籍政策。
答案 0 :(得分:1)
如果您可以访问iframe的内容,则可以:
parent.document.getElementById('client_site_iframe').style.display = 'block';
来显示iframe。