自己创建的a标签,执行点击事件,在safari浏览器没反应

本意是想用js动态创建一个A标签,然后赋URL地址。再触发其点击事件,让其在新标签页打开。

代码如下:

    var a = document.createElement('a');

    a.href = 'http://www.baidu.com';

    a.target = '_blank';

    document.body.appendChild(a);

    a.click();

这样在其他浏览器下都可以自动在新标签页打开百度。但在safari下不行。后来在网上搜索下了有关问题的解释,有同学说是safari下的A标签默认是没有绑定事件的,后来我就改成如下代码:

    var a = document.createElement('a');

    a.href = 'http://www.baidu.com';

    document.body.appendChild(a);

 

    var e = document.createEvent('MouseEvent');     

    e.initEvent('click', false, false);     

    a.dispatchEvent(e);

有人说:在safari下确实能跳转,但加上【a.target = '_blank';】后就不能跳转了。

 可是我试过还是可以跳转的,不知道会不会是因为版本问题

不知道是不是有大神也遇到过这种情况???

 

或者有没有其他的实现跳转的方式??

window.location.href='http://www.baidu.com'是可以跳转的

还有window.open也是可以

注:

safari测试版本:5.1.7(7534.57.2)

转载于:https://www.cnblogs.com/-lai/p/5918958.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值