资讯专栏INFORMATION COLUMN

有趣的API: history pushState/popstate 无刷新跳转

HitenDev / 721人阅读

摘要:摸鱼逛知乎看到这么一个问题这个看起来貌似很厉害的样子,搜搜看不得不说,张鑫旭真的厉害。目前忽略了這個參數,雖然他以後有可能會採用。路由器的无刷新跳转也是利用该完成的。引用资料张鑫旭与实例文档

摸鱼逛知乎看到这么一个问题

这个API看起来貌似很厉害的样子,搜搜看


不得不说,张鑫旭真的厉害。

API介绍

首先看看API如何使用:

history.pushState(state, title, url) : 无刷新的向浏览器 历史最前方 加入一条记录。

state(any) 需要保存的数据,这个数据在触发popstate事件时保存在event.state上。

title(string):

Firefox 目前忽略了這個參數,雖然他以後有可能會採用。如果以後改變了這個作法,傳送空白的字串應該還會是安全的。另外,你可以傳送一個短的標題來敘述你想要到的state。
目前没有发现有地方保存这个title,推测是state的说明?

url(string) 需要更改的url地址。

ps:pushState 需要至少两个参数。

popstate: 浏览器点击前进后退时触发的事件。event.state可以获取当前url下设置的state

另外获取pushState中设置的state不一定要在popstate事件中获取,直接history.state也可以拿到。

补充内容 pjax

pjax,利用ajaxpushState做成的和多页应用体验一致的SPA。github项目地址

现代路由框架的H5模式。

路由器的无刷新跳转也是利用该api完成的。另外,由于url变化,在用户复制分享时候由于路由未定义会出错,所以还需要服务端进行重定向处理。

引用资料:

张鑫旭:ajax与HTML5 history pushState/replaceState实例

mdn文档

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/50830.html

相关文章

  • 有趣APIhistory pushState/popstate 刷新跳转

    摘要:摸鱼逛知乎看到这么一个问题这个看起来貌似很厉害的样子,搜搜看不得不说,张鑫旭真的厉害。目前忽略了這個參數,雖然他以後有可能會採用。路由器的无刷新跳转也是利用该完成的。引用资料张鑫旭与实例文档 摸鱼逛知乎看到这么一个问题 showImg(https://segmentfault.com/img/bVOmkS?w=1558&h=934); 这个API看起来貌似很厉害的样子,搜搜看 show...

    smartlion 评论0 收藏0
  • 利用pushState, popState和location.hash等方法自己实现一个小型路由

    摘要:最后通过这些自己实现小型的路由。对象还提供方法这个方法用以监听浏览器在不同历史记录中进行切换,而触发相应的事件。这时调用方法后页面回退,同时页面发生刷新这时无法监听这个事件。所以可以进行降级使用来进行路由设计。不过,还提供了一个。 这篇文章主要是记录下HTML5中history提供的pushState, replaceStateAPI。最后通过这些API自己实现小型的路由。 关于win...

    ysl_unh 评论0 收藏0
  • history api看主流框架路由机制

    摘要:前端路由库的作用是改变地址栏,支持浏览器前进后退,并同步路由对应的视图,这里以及其依赖的库说一下路由机制原文地址前提首先简单介绍一下前端路由机制所依赖的事件及对应的事件对于支持新增方法的浏览器,可以通过设置来在浏览器栈中新增一条记录设置时 前端路由库的作用是改变地址栏,支持浏览器前进、后退,并同步路由对应的视图,这里以react-router及其依赖的history库说一下路由机制 原...

    Lyux 评论0 收藏0
  • HTML5 history API,创造更好浏览体验

    摘要:而唯一不引发刷新的参数并不会发送到服务器,因此服务器无法获得状态。目前建议设置为空字符串。此外请注意,及本身调用时是不触发事件的。我认为,按照渐进增强的思路,这样就是最好的了,也就是只使用较少的代码优化高级浏览器的使用体验。 HTML5 history API有什么用呢? 从Ajax翻页的问题说起 请想象你正在看一个视频下面的评论,在翻到十几页的时候,你发现一个写得稍长,但非常有趣的评...

    zgbgx 评论0 收藏0

发表评论

0条评论

HitenDev

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<