html 拦截 a 标签跳转

博客围绕前端开发展开,涉及HTML和JavaScript技术。HTML用于构建网页结构,JavaScript为网页增添交互性和动态效果,二者是前端开发的重要组成部分。

document.body.addEventListener('click', function () {
    // 兼容处理
    var target = event.target || event.srcElement;

    // 有些a 标签裹着图片之类的标签如img 这时候获取到的target是img,所以要往上遍历下
     while (target.nodeName.toLocaleLowerCase() !== 'body' &&     
         target.nodeName.toLocaleLowerCase() !== 'a') {
            target = target.parentNode || target.parentElement;
      }
    // 判断是否匹配目标元素
    if (target.nodeName.toLocaleLowerCase() === 'a') {

        // 处理完 a 标签的内容,重新触发跳转,根据原来 a 标签页 target 来判断是否需要新窗口打开
        
        var url = target.getAttribute("href")
        // 根据需要对不需要拦截的 a标签 判断处理
        if (!url ||
                url.indexOf('/') < 0 ||
                url.indexOf('javascript') > -1 ||
                url.indexOf('mailto:') > -1) return;
       // 对捕获到的 a 标签进行处理,需要先禁止它的跳转行为
        if (event.preventDefault) {
            event.preventDefault();
        } else {
            window.event.returnValue = true;
        }
        if (target.getAttribute("target") === '_blank') {
            window.open(url)
        } else {
            window.location.href = url
        }
    }
});

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值