浏览器history对象

雨点打透心脏的1/2处 2022-06-09 10:55 306阅读 0赞

“玲珑骰子安红豆,入骨相思知不知”
history 对象保存着用户上网的历史记录,从窗口被打开的那一刻算起。因为 history 是 window对象的属性,因此每个浏览器窗口、每个标签页乃至每个框架,都有自己的 history 对象与特定的window 对象关联。出于安全方面的考虑,开发人员无法得知用户浏览过的 URL。不过,借由用户访问过的页面列表,同样可以在不知道实际 URL 的情况下实现后退和前进。
使用 go() 方法可以在用户的历史记录中任意跳转,可以向后也可以向前。这个方法接受一个参数,表示向后或向前跳转的页面数的一个整数值。负数表示向后跳转(类似于单击浏览器的“后退”按钮),正数表示向前跳转(类似于单击浏览器的“前进”按钮)。来看下面的例子。

  1. //后退一页
  2. history.go(-1);
  3. //前进一页
  4. history.go(1);
  5. //前进两页
  6. history.go(2);

也可以给 go() 方法传递一个字符串参数,此时浏览器会跳转到历史记录中包含该字符串的第一个位置——可能后退,也可能前进,具体要看哪个位置最近。如果历史记录中不包含该字符串,那么这个方法什么也不做,例如:

  1. //跳转到最近的 wrox.com 页面
  2. history.go("wrox.com");
  3. //跳转到最近的 nczonline.net 页面
  4. history.go("nczonline.net");

另外,还可以使用两个简写方法 back() 和 forward() 来代替 go() 。顾名思义,这两个方法可以模仿浏览器的“后退”和“前进”按钮。

  1. //后退一页
  2. history.back();
  3. //前进一页
  4. history.forward();

除了上述几个方法外, history 对象还有一个 length 属性,保存着历史记录的数量。这个数量包括所有历史记录,即所有向后和向前的记录。对于加载到窗口、标签页或框架中的第一个页面而言,history.length 等于 0。通过像下面这样测试该属性的值,可以确定用户是否一开始就打开了你的页面。

  1. if (history.length == 0){
  2. //这应该是用户打开窗口后的第一个页面
  3. }

虽然 history 并不常用,但在创建自定义的“后退”和“前进”按钮,以及检测当前页面是不是用户历史记录中的第一个页面时,还是必须使用它。

发表评论

表情:
评论列表 (有 0 条评论,306人围观)

还没有评论,来说两句吧...

相关阅读

    相关 History对象

    window对象的history属性引用的是该窗口的History对象,该对象的属性与方法如下[![未命名][30145410-2555e2c3e74c4fc7a78cbf39