手机版 | 登录 | 注册 | 留言 | 设首页 | 加收藏
联系客服
当前位置: 网站首页 > 程序技巧 > 文章 当前位置: 程序技巧 > 文章

页面链接跳转历史URL不记录的兼容处理

时间:2021-12-30    点击: 次    来源:网络    添加者:佚名 - 小 + 大

1.阻止跳转a标签的链接

2.location.replace(href) 不生成新的历史记录, 但有bug

3.首先通过HTML5 history.replaceState()方法把当前URL地址替换成以个井号#结尾的目前链接地址;

4.执行location.replace('')刷新当前地址(此时#会忽略);

复制代码
(function(){
    var fnUrlReplace = function (eleLink) {
        if (!eleLink) {
            return;
        }
        var href = eleLink.href;
        if (href && /^#|javasc/.test(href) === false) {
            if (history.replaceState) {
                // 生成新的URL
                history.replaceState(null, document.title, href.split('#')[0] + '#');
                location.replace('');       // 刷新当前页面URL
            } else {
                location.replace(href);     // 不生成新的历史记录
            }
        }
    };

    document.getElementsByTagName('a')[0].onclick = function (event) {
        // 阻止跳转
        if (event && event.preventDefault) {
            event.preventDefault();    
        }
        fnUrlReplace(this);
        return false;
    };
}());

参考: http://www.zhangxinxu.com/wordpress/2017/02/page-link-url-history-null-not-record/

分享按钮

上一篇:js与asp 变量相互调用 变量互传的方法

下一篇:asp读取excel数据表时某列数据为字符、数值、空值等混合类型的处理办法

豫ICP备19032584号-1  |   QQ:80571569  |  地址:河南濮阳市  |  电话:13030322310  |  
Copyright © 2024 FE内容付费系统 版权所有,授权www.xingwp.cn使用 Powered by 66FE.COM