在Web前端开发中,我们经常会用到iframe这个控件。
但是这个控在内、外交互时,往往各个浏览器所用的关键字不同,很是麻烦,为了能够得到子iframe中的window对象,各家浏览器有着各家的指定,有的是window,有的是contentWindow等等也许还有我们不知道的。
但是从子页面访问父层页面,其本上大家都是window.parent就可以了。
那么通过这个特征,我们可以在子页面中,把自身的window对象传递给父页面就可以了,这样父页面就很轻松的访问子页面,再也不用靠虑如何从iframe对象上得到window对象了。
二话不说,我们先看代码:
父页面代码:
window.iframeWindow = null; function frameReady(subWindow){ window.iframeWindow = subWindow; //赋值 }; <iframe src = "xx" ></iframe>
子页面代码:
$(function(){ window.parent.frameReady(window); });
通过上面简单的代码,就可以在父页面中访问iframeWindow对象,直接得到了子页面的window对象,非常无脑也非常好用。
如果我有多个iframe该怎么办呢?
这种情况会稍微复杂一点,但是没关系。我们想继续使用上面的方案,就分析一下现状:
1.我们应该会需要一个类似iframeWindows的集合对象,用于管理所有子页面的window对象。
2.每个子页面在调用parent.frameReady时,必须靠诉父页面一个唯一名称,使得我们可以在父页面中对各个iframe进行精确访问
那么这下就简单了,子页面要做的事,无非就是一个名称、编号啥的,我们来看代码
window.subWindowName = "HelloWorldWindow"; $(function(){ window.parent.frameReady(window.subWindowName, window); });
那么父页面要做的事就是重构frameReady并增加一个参数
window.iframeWindows = {}; //这里变成了一个对象 function frameReady(name, window){ window.iframeWindows[name] = window; }; function getSubWindow(name){ return window.iframeWindows[name]; }
总结:
通过这种方案构建的页面存在以下优点:
1.父子页面的交互仅依赖于parent关键字(而以前的方式中,不仅依赖parent,还要依赖contentWindow、window等其它不确定关键字,最重要的是parent的支持还是非常好的)
2.window对象统一化,减少了每次使用时再请求的引用链,提高了运行的速度
3.最重要的一点:就是代码写起来轻松多了。
以上所述是小编给大家介绍的Javascript iframe交互并兼容各种浏览器的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]