Alv*_*aro 5 jquery plugins back-button jquery-address
从文档(http://www.asual.com/jquery/address/docs/)中可以看出,该插件有一个事件可以检测何时按下浏览器的后退/前进按钮.
$ .address.externalChange(FN)
我的问题是,是否有办法知道何时按下背部以及何时按下前进.例如,这将适用于两种情况:
$.address.externalChange(function() { console.log('back/forward pressed'); });
Run Code Online (Sandbox Code Playgroud)
谢谢.
据我所知,没有历史记录插件可以检测到底按下了哪个浏览器按钮。
您能做的最好的事情就是保留访问过的页面的历史记录,然后检查新页面在历史记录中是否比当前页面更靠前。当在没有后退/前进按钮的情况下重新访问页面时,您可能会使用以下代码得到错误的结果。
未经测试的示例代码:
var visitedPages = [$.address.path()];
var currentPage = $.address.path();
$.address.internalChange(function() {
visitedPages.push($.address.path());
});
$.address.externalChange(function() {
var newPage = $.address.path();
var currentPageIndex = -1;
var newPageIndex = -1;
for (var i = 0; i < visitedPages.length; i++) {
if (visitedPages[i] == currentPage) currentPageIndex = i;
if (visitedPages[i] == newPage) newPageIndex = i;
}
if (newPageIndex == -1 || currentPageIndex == -1) {
console.log("unkown button pressed");
} else {
if (newPageIndex > currentPageIndex) {
console.log('forward pressed');
} else
if (newPageIndex < currentPageIndex) {
console.log('back pressed');
} else {
console.log('page reloaded?');
}
}
});
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
855 次 |
最近记录: |