H5中的history方法Api介绍

摘要:history方法可以直接调用,例:history.pushState(),也可以用window.history.pushState()来调用。因为history是属于浏览器中的子对象,两种调用方法都是生效的;

下面来跟大家一起来捋捋history的Api方法和使用:

history.pushState(data,title,url):在浏览器中新增一条历史记录;

data会在onpopstate事件触发时作为参数传递过去,title为页面标题,url为页面地址;

history.replaceState(data,title,url):在浏览器中替换当前历史记录;

data会在onpopstate事件触发时作为参数传递过去,title为页面标题,url为页面地址;

history.length():当前历史列表中的历史记录条数;
window.onpopstate:实际上popstate是一个浏览器内置的点击事件,响应pushState和replaceState的触发调用;

    //当页面加载时   
     window.onload=function(){
        pushHistory();
    //新增浏览器事件监听(popstate为事件名,触发事件执行function)
      window.addEventListener("popstate",function(e){
          //括号里面应为业务代码(要做的事情)   
        },false);
      function pushHistory(){
    //定义对象
        var state={
           title:“title”,
           url:"#"
          };
    //调用history.pushState方法往浏览器历史记录上新增一条历史记录
       window.history.pushState(state,"title","#");
        }        
    }    
 history.back(-1):返回到当前页的上一页(原页面表单中的内容会保留)
 history.back(0):页面刷新
  history.back(1):当前页前进一页
  history.go(-1): 返回到当前页的上一页(原页面表单中的内容会丢失,效果基本和  
  history.back(-1)一样)
  history.forward():当前页面前进一页(和history.back(1)效果一样)

声名:

history方法可以直接调用,例:history.pushState(),也可以用window.history.pushState()来调用。因为history是属于浏览器中的子对象,两种调用方法都是生效的;


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_5682