如题。
使用情景如下:在一个页面中(a.html ),存在大量的不刷新 ajax 数据更新操作,每一次的 ajax 之后页面显示和 dom 结构发生变化。跳转到两一个页面( b.html )处理相关操作之后,通过 history.back ()返回到 a.html 页面。
需求如下:在通过 history.back ()返回之后,看到的 a.html 页面的显示和结构希望是完成最后一次 ajax 更新之后的情景,而不是初次进入 a.html 的情况。
尝试使用 history.pushState ()和 history.replaceState (),依然无法达到需求预期。
|  |      1orcusfox      2015-08-17 16:17:41 +08:00 这不就是 ajax 的短板么 | 
|  |      2loading      2015-08-17 16:36:00 +08:00 via Android 也许你还需要配合 localstorage | 
|  |      3ffffwh      2015-08-17 17:22:14 +08:00 "大量的不刷新 ajax 数据更新操作"大量是多少? 一般我是重新请求&重做一遍 dom | 
|  |      4FinalAir OP | 
|  |      669      2015-08-17 17:51:56 +08:00  3 分兩種情況: 一、重新打開頁面之後,通過 AJAX 獲取的狀態(例如用戶信息、列表數據等)要更新到最新數據; 二、重新打開頁面的時候,只要展示關閉頁面之前的數據即可; 如果是一:對每個 AJAX 操作做一個記錄,下次打開的重新執行這些操作; 如果是二:整個頁面的 DOM 結果保存到 localstorage 中,下次打開的時候直接讀取替換當前 DOM ; | 
|  |      7sneezry      2015-08-17 20:12:42 +08:00 via iPhone hash 记状态 | 
|  |      8ChefIsAwesome      2015-08-17 20:30:29 +08:00 via Android  1 一,跳 b 也走 ajax ,然后 history 或者 hash 改 URL , a 的状态就保留了。 二, a 的 ajax 是响应某个状态的, hash 或者 cookie , local storage 等等。进页面的时候先读那个状态。用户的操作也是改变那个状态。 | 
|  |      9FrankFang128      2015-08-17 20:33:09 +08:00 via Android 每次刷微博 /推特都会想到楼主这个问题。 他们都没解决,楼主。。。 | 
|  |      10FrankFang128      2015-08-17 20:33:52 +08:00 via Android 新页面打开不就好了 ,哈哈 | 
|  |      11dong3580      2015-08-17 21:15:22 +08:00  1 1. localstorage 缓存对象; 2. 用 angularjs 的$scope 记下对象,无需使用 history 保存 dom 状态,直接更新状态; 3. 跳第二个页面的时候后端异步处理,返回处理后的 key ,带到返回页面请求结果。 | 
|  |      12FinalAir OP |