IE下,动态创建的iframe在异步提交时会跳转的问题的解决

转载的文章 正好能解决燃眉之急,多谢原作者先。

-------------------------------------------------------------------------华丽的分隔符-----------------------------------------------------------

在一些前端项目中可能要用到动态创建iframe的需求,例如无刷新ajax上传文件。但是在IE下创建带有name的iframe会有个bug,创建的代码如下:

var iframe = document.createElement('iframe');
iframe.name = 'test';

上面的这段javascript代码在IE下赋不了name属性!!! 即iframe.name = 'test';这段代码未执行。

在IE中我们可以使用下面的代码来动态创建带有name的iframe:

var iframe = document.createElement('<iframe name="test">');

但是上面的代码在非IE浏览器下却报错,这时候我们可以使用判断IE,如果是ie则使用第二段方法动态创建iframe,或者我们可以捕获异常,如下面的代码:

var iframe;
try {
    // IE浏览器适用
    iframe = document.createElement('<iframe name="test">');
} catch (ex) {
    // 非IE浏览器
    iframe = document.createElement('iframe');
   iframe.name = 'test'; }

通过这样的方法 就可以了~~

我这边在完善一下吧

function createIframe(iframeName){
  var iframe;
  try {
    iframe = document.createElement('<iframe name="' + iframeName + '">');    
  }catch (ex){
    iframe = document.createElement('iframe');
    iframe.name = iframeName;
  }
  document.body.appendChild(iframe);
}

到这里应该就可以了,下面的是自己刚加的 还没试验。

转载于:https://www.cnblogs.com/lxin/archive/2012/10/11/2720280.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值