- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
您好,有以下 jQuery 事件:
listItems.on('click', function(ev) {
ev.preventDefault();
reload = true;
var url = jQuery(this).attr('data-url');
history.pushState({}, '', url);
...
}
它通过 AJAX 加载动态内容并推送历史状态以修改浏览器中的 URL 从 www.domain.com
到 www.domain.com/page-x
。我通过 AJAX 加载内容的唯一原因是我需要动画页面转换。如果您转到 www.domain.com/page-x
,您将获得普通的 HTML 页面。
如果在单击 listItem 后用户单击其浏览器上的后退按钮,则会出现问题。网址从 www.domain.com/page-x
变回 www.domain.com
,但页面没有重新加载。这就是我添加此事件的原因:
window.onpopstate = function() {
if (reload == true) {
reload = false;
location.reload();
}
}
如果当前页面是通过 AJAX 加载的,它会在 url 更改后重新加载页面。它工作正常,但现在我遇到了其他问题:
任何想法/解决方案将不胜感激。
最佳答案
而不是使用 reload=true
你应该依靠event.state
这样当popstate
发生这种情况时,您会得到您为该 URL 记录的内容的快照。
Manipulating the browser history (MDN)
例如:
listItems.on('click', function(ev) {
ev.preventDefault();
var url = jQuery(this).attr('data-url');
history.pushState({ action: 'list-item-focused' }, '', url);
...
}
然后:
window.onpopstate = function(e) {
/// this state object will have the action attribute 'list-item-focused'
/// when the user navigates forward to the list item. Meaning you can
/// do what you will at this point.
console.log(e.state.action);
}
您可能应该避免在用户返回时重新加载整个页面,而是将您的内容动画化回原来的位置,这样您就不会破坏页面。然后,您可以通过检查 event.state.action
来区分登录页面和列表页面。并相应地对您的回答进行编码。
window.onpopstate = function(e) {
if ( e.state.action == 'list-item-focused') {
/// a list item is focused by the history item
}
else {
/// a list item isn't focused, so therefore landing page
/// obviously this only remains true whilst you don't
/// make further pushed states. If you do, you will have to
/// extend your popstate to take those new actions into account.
}
}
我相信你知道这一点,但是 pushState
不完全跨浏览器,因此您还应该预料如果不支持这些方法,用户可能会遇到什么情况。
此外,由于您使用的是 jQuery,因此您可以很容易地在状态对象中存储更多有用的信息,这可以帮助您增强对 popstate
的 react 。 :
history.pushState({
action: 'list-item-focused',
listindex: jQuery(this).index()
});
您必须记住,您存储的任何数据都是序列化的,这意味着它很可能会转换为某种形式的非交互式字符串或二进制数据。这意味着您不能存储对元素或其他“事件”实例的引用;因此我存储的是列表项索引。
有了上面的内容,你现在知道发生了什么 Action 以及在什么列表项上,你可以在另一端使用以下方法检索:
listItems.eq(event.state.listindex)
MDN 有关于你应该做什么的说法 onload
.
Reading the current state
When your page loads, it might have a non-null state object. This can happen, for example, if the page sets a state object (using pushState() or replaceState()) and then the user restarts her browser. When your page reloads, the page will receive an onload event, but no popstate event. However, if you read the history.state property, you'll get back the state object you would have gotten if a popstate had fired.
You can read the state of the current history entry without waiting for a popstate event using the history.state property like this:
简单地说,他们只是建议您应该注意当前的 history.state
当页面加载时,并根据您的 state.action
采取相应行动描述。这样您就可以支持在页面生命周期内触发的两个事件,即 popstate
以及当用户直接跳转到导致页面加载的历史记录状态时。
因此,考虑到上述情况,最好的结构可能是这样的:
window.onpopstate = function(e) {
reactToState(e.state);
}
window.onload = function(){
history.state && reactToState(history.state);
}
var reactToState = function(state){
if ( state.action == 'list-item-focused') {
/// a list item is focused by the history item
}
else {
/// a list item isn't focused, so therefore landing page
/// obviously this only remains true whilst you don't
/// make further pushed states. If you do, you will have to
/// extend your popstate to take those new actions into account.
}
}
为了简单起见,我使用了内联事件监听器,因为您的示例也是如此,但是建议使用 addEventListener
和 attachEvent
(仅限 IE)方法...或者更好,因为您使用的是 jQuery。
jQuery(window)
.on('popstate', function(e) {
reactToState(e.originalEvent.state);
}
.on('load', function(){
history.state && reactToState(history.state);
}
;
显然,为了在两种状态之间移动,您需要知道这两种状态是什么;这意味着有一些方法可以记录你当前的状态——这样你就可以与新状态进行比较并采取相应的行动。由于您只有两种状态,因此这可能不是必须的,但我敦促您始终考虑比目前更复杂的可能性。
我不知道你的代码布局,所以很难推荐你应该在哪里放置变量和其他类似的项目。但是,无论您如何存储信息,都不会改变这样一个事实:如果您这样做,它会让您的生活和代码更轻松:
var reactToState = function(state){
var currentState = reactToState.currentState || {};
if ( !currentState.action ) { currentState.action = 'start'; }
if ( state.action == 'list-item-focused') {
if ( currentState.action == 'start' ) {
/// here we know we are shifting from the start page to list-item
}
}
else {
if ( currentState.action == 'list-item-focused' ) {
/// here we know we are shifting from the list-item to the start
}
}
/// as the state will be global for your application there is no harm
/// in storing the current state on this function as a "static" attribute.
reactToState.currentState = state;
}
更好的是,如果您不反对 switch 语句,您可以使上面的代码更具可读性:
var reactToState = function(state){
/// current state with fallback for initial state
var currentState = reactToState.currentState || {action: 'start'};
/// current to new with fallback for empty action i.e. initial state
var a = (currentState.action||'start');
var b = (state.action||'start');
switch ( a + ' >> ' + b ) {
case 'start >> list-item-focused':
/// animate and update here
break;
case 'list-item-focused >> start':
/// animate and update here
break;
}
/// remember to store the current state again
reactToState.currentState = state;
}
关于javascript - AJAX 内容和浏览器导航按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22063144/
我的“登录”是在 IE 浏览器中进行的,登录后,如果我单击链接,它们就会在 Chrome 浏览器中打开。如何在同一个测试用例中将我当前的浏览器从 IE 切换到 Chrome。如果我创建一个 chrom
您好,我不明白在 Firefox 的内容属性中使用的特殊字符的不同显示行为。我已经剥离了一切并创造了一支笔: http://codepen.io/rpkoller/pen/Fbgav 在其“基本形式”
我正在研究 Spring Data REST,特别是 HAL 浏览器。我一直在关注 http://docs.spring.io/spring-data/rest/docs/current/refere
我正在使用工具提示,在 ie 上出现定位错误。我放了jquery浏览器代码 我的工具提示 $('.tooltip').tooltip({ position: "bottom center"
我应该如何处理蓝鸟协程中的错误? 我使用co in节点已有一段时间,它具有出色的捕获功能。 co(function*() { return new Promise(function(resol
package webviewbrowser; import java.util.List; import javafx.application.Application; import javafx.
我有一些 JavaScript 在同一域上的两个独立服务器之间共享请求。 .com 是 JavaScript 中域的要求吗? 在这种情况下,两台服务器都位于 .abc.tyy 域上,tyy 通常是 .
package webviewbrowser; import java.util.List; import javafx.application.Application; import javafx.
我正在尝试构建仍支持 NPAPI 的先前版本的 Chromium 浏览器。我已经获得了代码,并且可以使用 stand build 命令在我的 mac 上构建最新版本的 Chromium gclient
我环顾四周,找不到 browscap 的 Python 等效项(我在 PHP 中使用它来检测给定的用户代理字符串是什么浏览器。 我希望我不必自己写......:P 最佳答案 看看这个,它应该做你想要的
是否有任何 chrome 或 firefox 扩展允许 javascript 在客户端 PC 中创建写入文件? 最佳答案 你想做什么? HTML5 有一个 File API .这是最好的解决方案,因为
当我点击链接或刷新或关闭标签页时,我有这段代码会发出警报。 但我需要在关闭 窗口(选项卡)上仅 发出警报。怎么做? 我的网站上有很多外部和内部链接。
我目前正在尝试使用 Browserify + Angular,但我遇到了一个奇怪的问题。我在我的 Controller 的子目录中创建了一个名为 controllers/start-controlle
我正在为客户(项目已被接受,但现在是解释不同功能的问题)写一份详细的估算,以开发一个响应式布局的网站。 这不是我第一次进行此类开发,但这是一个关键客户,必须铺平道路。 布局将从 300px 宽度调整到
我在时事通讯上设计了一些黑底白字。由于时事通讯在打印时看起来不错且可读。我需要使布局和文本与浏览器中的内容相似。 通常情况下,黑色文本和无背景颜色是浏览器/网络邮件客户端的默认打印样式吗? 最佳答案
我有一个使用 GWT/mGWT 构建的移动友好网络应用程序。该应用程序有白色输入文本框和深灰色输入文本。但是,在 Android 浏览器上,文本显示为白色,因此是不可见的。我尝试的所有 CSS 都无法
我创建了一个带有选择输入的页面来更改正在使用的 jQuery UI 主题。当主题更改时,它会存储在 cookie 中。页面加载时,如果 cookie 存在,则恢复主题,否则加载默认主题。 当我使用 F
在我的 CSS 中,我使用了以下代码片段: word-break: break-word; -webkit-hyphens: auto; hyphens: auto; 渲染引擎如何知道在所有不同语言中
我的网络浏览器 Safari 有问题,我在 Chrome、FireFox 中测试了我的网站。 Safari 版本也是正确的,但是,当需要在 1920x1080 或更高分辨率下对其进行测试时,它无法正常
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我是一名优秀的程序员,十分优秀!