关于onpopstate

简介:

Magix第1个版本做了hash与pushState之间的切换兼容
关于url解析可以看这篇

当时在做history.pushState时(2012年),发现对于onpopstate对于不同的浏览器是不一样的。

$(window).on("popstate", function() {
    alert('popstate');
});

上述代码在chrome中页面加载完成时竟然会弹出 popstate
现在仍然能够搜出很多在stackoverflow问这个问题的人,如
http://stackoverflow.com/questions/4688164/window-bind-popstate
http://stackoverflow.com/questions/6421769/popstate-on-pages-load-in-chrome/

当时阅读了pjax,使用了类似如下的解决方案

var initialURL = location.href,popped
$(window).bind('popstate', function(event) {
  var initialPop = !popped && location.href == initialURL
  popped = true
  if ( initialPop ) return

当然,现在并没有这样的问题了

目录
相关文章
|
7月前
|
C语言
用while语句实现循环
用while语句实现循环
70 1
|
7月前
|
开发工具 Swift git
iOS组件化之具体实现
iOS组件化之具体实现
46 0
|
7月前
|
存储 Python
用函数实现求所有(50~100)之间素数的和
用函数实现求所有(50~100)之间素数的和
94 0
|
XML 存储 JSON
14 Tornado - XSRF
14 Tornado - XSRF
32 1
|
存储 缓存 运维
Nacos-手写配置中心基本原理
手写配置中心基本原理
173 0
|
存储 搜索推荐 PHP
攻防世界 初识web
攻防世界 初识web
74 0
|
前端开发
react中隐藏属性
react中隐藏属性
【单片机】数码管矩阵显示
【单片机】数码管矩阵显示
91 0
|
设计模式 安全 Java
【精通函数式编程】(二)代码的行为参数化传递
在我们平时的工作中,我们的需求是不断变化的,这个接口怎么设计更通用一些呢?
【精通函数式编程】(二)代码的行为参数化传递
|
Java 数据库连接 数据库
装饰者模式学习笔记
快速学习装饰者模式
装饰者模式学习笔记