js 推断 当页面无法回退时(history.go(-1)),关闭网页

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 推断 当页面无法回退时(history.go(-1)),关闭网页相关的知识,希望对你有一定的参考价值。

在做一个Web项目时遇到一个需求,当页面没有前驱历史记录时(就是当前为新弹出的页面,没法做goback操作即history.go(-1)),点击返回button时直接关闭页面,否则就退回到前一页。

遇到的问题就是怎样推断 是否有history能够回退,这个很麻烦,由于没有这种函数直接能获取到。仅仅能通过history.length这个变量做变通的处理。可是对于IE。和非IE的length的返回值不同,ie: history.length=0, 非IE的为1。因此写了一个函数实现前面所需求的这个功能。分享给大家。

/**
 * 返回前一页(或关闭本页面)
 * <li>假设没有前一页历史。则直接关闭当前页面</li>
 */
function goBack(){
    if ((navigator.userAgent.indexOf('MSIE') >= 0) && (navigator.userAgent.indexOf('Opera') < 0)){ // IE
        if(history.length > 0){
            window.history.go( -1 );
        }else{
            window.opener=null;window.close();
        }
    }else{ //非IE浏览器
        if (navigator.userAgent.indexOf('Firefox') >= 0 ||
            navigator.userAgent.indexOf('Opera') >= 0 ||
            navigator.userAgent.indexOf('Safari') >= 0 ||
            navigator.userAgent.indexOf('Chrome') >= 0 ||
            navigator.userAgent.indexOf('WebKit') >= 0){

            if(window.history.length > 1){
                window.history.go( -1 );
            }else{
                window.opener=null;window.close();
            }
        }else{ //未知的浏览器
            window.history.go( -1 );
        }
    }
}


以上是关于js 推断 当页面无法回退时(history.go(-1)),关闭网页的主要内容,如果未能解决你的问题,请参考以下文章

火狐中很奇怪的history.go(-n)的问题

vue中常用的两中页面刷新的方式和页面回退

前端技术之:Vue.js应用回退或刷新界面时提示用户保存修改

javascript 如何实现点击按钮让它回退到前一页面。具体怎么实现。在线等。

回退时 UITableViewController 单元格保持突出显示

JS定时刷新页面及跳转页面的方法