Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 540|回复: 0

Javascript iframe交互并兼容各种浏览器的解决方案

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-7-22 14:40:23 | 显示全部楼层 |阅读模式

    在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. 最重要的一点:就是代码写起来轻松多了。

     

    另外:对于window.subWindowName的构建方式很多,这个即可以写死,也可以通过父层页面的src利用url传递进来。怎么使用就看自己的需求了。

     

    原文地址 http://www.zizhusoft.com/note/show.aspx?id=14520a63-c7e8-42e9-a87e-77aec7adab0a 。

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-19 18:40 , Processed in 0.072184 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表