IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

JS操作iframe里的dom

WEB前端开发 2010-07-23 00:08:26 累计浏览 3,243 次
本机暂存

    看到断桥残雪对我上一篇日志的回复我也学习了一下JS操作iframe里的dom;主要参考了断桥残雪的《用JavaScript在IE和Firefox下进行iframe的DOM操作》和支付宝UED的《用JS访问操作iframe里的dom》,非常不错的两篇文章。

一、父级窗口操作iframe里的dom

    JS操作iframe里的dom可是使用contentWindow属性,contentWindow属性是指指定的frame或者iframe所在的window对象,在IE中iframe或者frame的contentWindow属性可以省略,但在Firefox中如果要对iframe对象进行编辑则,必须指定contentWindow属性,contentWindow属性支持所有主流浏览器

    相关的还有一个contentDocument属性,这个属性是指指定的frame或者iframe所在的document对象,但是悲剧的是,ie6-ie7并不支持这个属性。

    ie6和ie7还可以使用document.frames["iframe Name"]或者document.frames["iframe ID"]来获取相当于contentWindow属性,而firefox和chrome并不支持这些document.frames["iframe Name"]或者document.frames["iframe ID"],但是window.frames["iframe Name"]或window.frames[index](index是索引值)也支持所有主流浏览器

    这个可以看实例:http://www.css88.com/demo/iframe-correspond/index-test.html

    我们知道document对象是window对象的一个子对象,所以我们可以通过document.getElementById(“iframe ID”).contentWindow.document来获取iframe的document对象,相当于contentDocument属性。

二、iframe里的js操作父级窗口的dom

    iframe里的js要操作父级窗口的dom,必须搞懂几个对象:

    parent是父窗口(如果窗口是顶级窗口,那么parent==self==top),

    top是最顶级父窗口(有的窗口中套了好几层frameset或者iframe),

    self是当前窗口(等价window),

    opener是用open方法打开当前窗口的那个窗口;

    这样iframe里的js要操作父级窗口的dom可以通过parent,top这些对象来获取父窗口的window对象,例如:

    parent.document.getElementById(“dom ID”);

    parent,top还能调用父级窗口的的js方法,比如,getIFrameDOM(iID)是父级窗口的一个方法,那么iframe里可以使用parent.getIFrameDOM(“wIframeA”)来调用父级窗口的getIFrameDOM(iID)方法;

    ――――――――――――――――

    查看一下JS操作iframe里的dom的demo:http://www.css88.com/demo/iframe-correspond/

    虽然iframe在现在WEB开发中越来越少用到了,但是iframe还有很多值得使用的地方,比如使用iframe解决跨域问题.关于iframe还有很多东西要学习,比如iframe自适应高度,使用iframe解决跨域问题,iframe加载问题,iframe加载性能问题等等,还有很多东西要学习,

同分类推荐文章

  1. 新特性速递:focus()行为新增focusVisible控制 (2026-05-29 16:23:06)
  2. Algorithmic Theming Engines: Building Self-Correcting Color Systems With `contrast-color()` (2026-05-28 21:00:00)
  3. Revealing Text With CSS letter-spacing (2026-05-27 20:37:33)

查看更多 前端 文章 →

建议继续学习

  1. JQuery实现Excel表格呈现 (累计阅读 48,263)
  2. 深入理解Javascript之执行上下文(Execution Context) (累计阅读 18,263)
  3. 从输入 URL 到页面加载完成的过程中都发生了什么事情? (累计阅读 15,802)
  4. 图片动态局部毛玻璃模糊效果的实现 (累计阅读 14,764)
  5. 天朝第二代身份证号码的验证机制 (累计阅读 14,684)
  6. HTML 5 的data-* 自定义属性 (累计阅读 14,242)
  7. 分享一个JQUERY颜色选择插件 (累计阅读 14,142)
  8. 什么是全栈工程师? (累计阅读 13,943)
  9. 快速排序(Quicksort)的Javascript实现 (累计阅读 11,640)
  10. 7 天打造前端性能监控系统 (累计阅读 11,102)