页面刷新跳转后,导航栏高亮显示跳转前的点击位置

需求:好比有一个二级或三四级的菜单栏,页面不跳转时实现高亮显示是很容易的,网上有不少这样的素材。可是页面一跳转,新页面可就记不住你在上一个页面点击的位置了,也就不可能高亮显示。而且不少时候,跳转后的页面菜单栏是后台动态生成的,也就是菜单栏栏目不固定,那么就不可能给菜单栏高亮效果写死。不知道这个事利用先后台交互去作会不会容易点,可是如今是要用纯前台实现。正则表达式

 

实现原理一:这时候必须找个地方给它把点击的位置存起来,等页面跳转后,从那个地方把标记取出来,再给导航相应的位置作高亮处理就行了。浏览器

 

方法1:利用 H5 的 localStorage ,可是IE67不兼容,IE8还存在问题,项目要求兼容性的,因此干脆没试过这方法。可是不要求兼容性的能够尝试一下,我还没来得及……安全

 

方法2:隐藏变量的方法应该也可行吧,可是页面须要异步处理,就是说要把隐藏变量放到不被刷新的位置,然额~咱们是页面全刷新,这方法用不到。cookie

 

方法3:利用 cookie 存储,可是 cookie 有安全性问题,项目里不让用。虽然不让用,可是我也贴出来吧。这是3个封装方法,能够直接调用的:异步

function getCookie(key){
    var arr1 = document.cookie.split('; ');
    for(var i=0;i<arr1.length;i++){
        var arr2 = arr1[i].split('=');
        if(arr2[0]==key){
            return decodeURI(arr2[1]);
        }
    }
}

function setCookie(key,value,t){
    var oDate = new Date();
    oDate.setDate(oDate.getDate() + t);
    document.cookie = key + '=' + value + ';expires=' + oDate.toGMTString();
}

function removeCookie(key){
    setCookie(key,'',-1);
}

点击的时候调用 setCookie(),标记位置。而后页面跳转初始化的时候调用 getCookie(),取出标记,高亮显示菜单。测试

可是测试的时候有个问题,就是IE下 setCookie()方法放进去的值,页面跳转时就被清掉了,我还没来得及查缘由。火狐下测试没问题,谷歌本地测不了。url

 

方法4:利用 url 传参,我用的是这个方法,跳转后用 getUrlParam() 封装方法把参数取出来。spa

window.onload = function(){
//获取url中的参数
    function getUrlParam(name) {
        var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //构造一个含有目标参数的正则表达式对象
        var r = window.location.search.substr(1).match(reg);  //匹配目标参数
        if (r != null) return unescape(r[2]); return null; //返回参数值
    }

    var lv = getUrlParam('lv');
    var aId = getUrlParam('aId');
}

遇到的问题:若是是外连接的话,外连接自己就有参数,再加上我这一堆参数,跳转后就会出现问题。我是在初始化时循环导航栏的连接,就不给外链加标记参数了,就解决了。code

我看到网上说,这种方法的缺点是在浏览器缓冲阶段,会看不到高亮。等页面加载完或导航栏加载完一段时间,才会变成高亮,有一个时间延迟。对象

 

实现原理二:

方法5:页面跳转初始化时就把 window.location.href 与导航栏的连接地址去作匹配,匹配上的就加高亮显示。我准备接下来写四级菜单的时候用一下这个方法,还不知道会不会出现问题,有问题再来补充……

相关文章
相关标签/搜索