H5-历史管理

触发历史管理:1通过跳转页面  2hash # 3.pushState

 

第一个原始版本:

 var oBtn=document.getElementById("btn");
   var oBox=document.getElementById("box");
   var json={};
   oBtn.onclick=function(){
      var num=Math.random();
      var arr=randomNum(35,7);
      json[num]=arr;
      oBox.innerHTML=json[num];
      window.location.hash=num;
    }

    //一旦hash更改就更改oBox的innerHTML
    window.οnhashchange=function () {
        oBox.innerHTML=json[window.location.hash.substring(1)];
    }

    /*
    randomNum(iAll,iNow)随机从iAll中获得iNow位数的新数组
     */
   function randomNum(iAll,iNow){
        var arr=[];
        var newArr=[];
       for(var i=0;i<=iAll;i++){
           arr.push(i);
       }
       for(var i=0;i<iNow;i++){
           newArr.push(arr.splice(Math.floor(Math.random()*arr.length),1));
       }
        return newArr;
   }

第二种方法:需要打开WindowsWAMP,在里面运行

var oBtn=document.getElementById("btn");
   var oBox=document.getElementById("box");
   var json={};
   oBtn.onclick=function(){
      var  arr=randomNum(35,7);
       history.pushState(arr,"");//添加数据
       oBox.innerHTML=arr;
    }
window.onpopstate
=function (ev) { var ev=ev||event; oBox.innerHTML=ev.state; //读取数据 } /* randomNum(iAll,iNow)随机从iAll中获得iNow位数的新数组 */ function randomNum(iAll,iNow){ var arr=[]; var newArr=[]; for(var i=0;i<=iAll;i++){ arr.push(i); } for(var i=0;i<iNow;i++){ newArr.push(arr.splice(Math.floor(Math.random()*arr.length),1)); } return newArr; }

 

转载于:https://www.cnblogs.com/zz-mystudy/p/6817337.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值