弹出的iframe 表单无法获取焦点

昨天被朋友问到这个问题,

说一个弹窗里面包含一个编辑字段的iframe,在IE下面 第二次弹出的时候,弹窗中的元素便不能获取焦点。

开始怀疑是z-index的原因,修改无效。

后来搜索到这篇文章: 

http://www.dewen.org/q/2662

 

明白了原因,也就是关闭弹窗的时候 简单的移除了弹窗,没有对iframe进行清理,这样内存里面相当于还有一份iframe的实例,

这就造成了第二次弹窗 元素无法获取焦点。

解决方法可以参照上面这篇文章,没有亲自验证。

对于关闭按钮存在于弹出的iframe中的,可以在父层窗口准备一个移除iframe的方法,在关闭的时候运行一下,销毁需要关闭的iframe实例。

 

var clearIframe = function(f){
            try{
                f.contentWindow.document.write('');
                f.contentWindow.close();
f.parentNode.removeChild(frame);
            }catch(e){}

        };  

 

var close = function(){ if(typeof top.clearIframe == 'function'){ top.clearIframe(self) }  /*...其他要做的...*/ };

这样再弹出的就是新的iframe而不和内存中的残留冲突了。 

 

 

转载于:https://www.cnblogs.com/trance/archive/2012/10/12/2721450.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值