跨域iframe高度自适应(兼容IE/FF/OP/Chrome)

跨域iframe高度自适应(兼容IE/FF/OP/Chrome)
 
跨域iframe高度自适应

采用JavaScript来控制iframe元素的高度是iframe高度自适应的关键,同时因为JavaScript对不一样域名下权限的控制,引起出同域、跨域两种状况。javascript

因为客户端js使用浏览器的同源安全策略,跨域状况下,被嵌套页面若是想要获取和修改父页面的DOM属性会出现权限不足的状况,提示错误:Permission denied to access property 'document'。这是由于除了包含脚本的文档载入的主机外,同源策略禁止客户端脚本连接到其余任何主机或者访问其余任何主机的数据。这意味着访问一个web服务的javascript代码一般只有在它也驻留在Web服务自己所在的同一个服务器的时候才有用。html

因此在跨域状况下,咱们遇到的问题就是:父窗口没法得到被嵌套页面的高度,并且被嵌套页面也没法经过驻留在其服务器上的js修改父窗口Dom节点的属性。因此咱们须要一个媒介,来得到被嵌套页面的高度同时又能修改主界面iframe节点的高度。java

思路:现 有主界面main在域a下,被嵌套页面B在域b下,被嵌套页面B又嵌套一个在域a下的中介页面A。 当用户打开浏览器访问mail.html的时候载入B,触发B的onload事件获取其自身高度,而后B载入A,并将高度值做为参数赋值给A的 location对象。这样A就能够经过location.hash得到B的高度。(location是javascript里边管理地址栏的内置对象,好比location.href就管理页面的url,用location.href=url就能够直接将页面重定向url。而location.hash则能够用来获取或设置页面的标签值。好比http://domain/#admin的location.hash="#admin"。利用这个属性值能够作一些很是有意义的事情。)。因为A和main页面同域,因此能够修改main的dom节点属性,从而达到咱们设置iframe标签高度的目的。web

关键代码:跨域

iframe主页面:main.html浏览器

<iframe id="iframeB"  name="iframeB" src="www.b.com/B.html" width="100%" height="auto" scrolling="no" frameborder="0"></iframe>

 

iframe嵌套页面:B.html安全

<iframe id="iframeA" name="iframeA" src="" width="0" height="0" style="display:none;" ></iframe>

<script type="text/javascript">
function sethash(){
hashH = document.documentElement.scrollHeight; //获取自身高度
urlC = "www.a.com/A.html"; //设置iframeA的src
document.getElementById("iframeA").src=urlC+"#"+hashH; //将高度做为参数传递
}
window.onload=sethash;
</script>



中介页面:A.html
服务器

<script>
function pseth() {
var iObj = parent.parent.document.getElementById('iframeB');//A和main同域,因此能够访问节点
iObjH = parent.parent.frames["iframeB"].frames["iframeA"].location.hash;//访问本身的location对象获取hash值
iObj.style.height = iObjH.split("#")[1]+"px";//操做dom
}
pseth();
</script>

同域状况下就不用多说了,直接在被嵌套的页面B中获取其自身高度并操做其父窗口main的dom属性便可。 dom

相关文章
相关标签/搜索