给页面点击链接加了转圈圈和解决遇到的bug

Posted 0banana0

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了给页面点击链接加了转圈圈和解决遇到的bug相关的知识,希望对你有一定的参考价值。

今天遇到一个问题,之前给整个网站上的链接加了loading,今天遇到在ios的chrome和safari下点击进入新页面然后点击浏览器的返回按钮,loading还在,并且一直存在,最后网上搜到了解决方案特记录下

 

点击事件加loading:

$(document).on("click", "a[href!=‘‘][href!=‘#‘][href!=‘javascript:void(0)‘][href!=‘javascript:void(0);‘][href!=‘javascript:;‘]", function () {
    var href = $(this).attr(‘href‘);
    var target = $(this).attr(‘target‘);
    var a_pageindex = $(this).data("pageindex");

    if ($(this).hasClass(‘fancybox‘)) {
        //弹出层的不loading
    } else if (target != undefined && target == "_blank") {
        //有_blank的不loading
    } else if (href == undefined || href.indexOf("plus.google.com") > 0) {
        //没有href的不loading 或者google分享不loading
    } else if ($(this).data("pageindex") != undefined) {
        //ajax 分页空间的分页按钮不需要
    } else if (isCtrl) {
        //如果按着ctrl键不执行
    } else {
        //href中以#开头的不loading
        if (href.substring(0, 1) != ‘#‘ && href.indexOf("javascript:") == -1) {
            LinkLoading(true);
        }

    }
});

解决ios的chrome和safari返回继续loading:

//瀏覽器回退頁面一直轉圈
if ($(window).width() < 1024) {
    var detectBack = {
        initialize: function () {
            //监听hashchange事件
            window.addEventListener(‘hashchange‘, function () {
                //为当前导航页附加一个tag
                this.history.replaceState(‘hasHash‘, ‘‘, ‘‘);

            }, false);

            history.pushState(1, ‘‘, ‘‘)
            window.onpopstate = function (e) {
                if (!e.state) {
            //fix chrome window.history.back();
//侦测是用户触发的后退操作, dosomething //这里刷新当前url //window.location.reload(); } }; } } detectBack.initialize(); //fix ios safair window.onpageshow = function (event) { if (event.persisted) { window.location.reload() } }; }

 

以上是关于给页面点击链接加了转圈圈和解决遇到的bug的主要内容,如果未能解决你的问题,请参考以下文章

HTML代码片段

HTML代码片段

QWebEngineView加载url后直接点击链接没有反应要怎么解决

微信小程序代码片段

word里面,给图片加了个边框,怎么调边框和图片之间的距离?

vue echarts 遇到的bug之一 无法渲染的问题