History API - 捲動還原
透過集合功能整理內容
你可以依據偏好儲存及分類內容。
使用 History API 管理網址的做法很實用,但正如如此,這是優質網頁應用程式的重要功能。但缺點之一就是會儲存捲動位置,更重要的是,每當您掃遍歷史記錄時就「還原」。這通常表示捲動位置會自動改變時,不會突然跳轉,尤其是當應用程式開始轉換,或以任何方式變更網頁內容時。最終反而會對使用者體驗造成負面影響。
更糟的是,這幾乎沒有辦法解決:Chrome 會在 scroll
事件之前觸發 popState
事件。也就是說,您可以在 popState
中讀取目前捲動位置,然後在 scroll
事件處理常式中使用 window.scrollTo
(Ewww,但至少可以這麼做!) 對該事件進行反向操作。不過,Firefox 會在 popState
「之前」觸發 scroll
事件,所以您不知道舊的捲動值是否可還原。哼!
但好消息是,這個問題的解決方法之一:history.scrollRestoration
。其中包含兩個字串值:auto
可保留目前所有內容 (且為預設值),而 manual
代表使用者會取得使用者掃遍應用程式記錄時可能需要的任何捲動變更。如有需要,您可以在使用 history.pushState()
推送歷史記錄項目時,追蹤捲動位置。
這項新功能雖然是全新的實驗功能,但真的很出色,因此在使用前,還是請您先檢查可供使用:
if ('scrollRestoration' in history) {
// Back off, browser, I got this...
history.scrollRestoration = 'manual';
}
Chrome 46 以上版本可讓您找到 history.scrollRestoration
,也可以按這裡查看規格。
別忘了提供意見給其他廠商,如果您希望他們也對「scrollRestoration
」提供支援,請告訴我們。
除非另有註明,否則本頁面中的內容是採用創用 CC 姓名標示 4.0 授權,程式碼範例則為阿帕契 2.0 授權。詳情請參閱《Google Developers 網站政策》。Java 是 Oracle 和/或其關聯企業的註冊商標。
上次更新時間:2015-09-01 (世界標準時間)。
[{
"type": "thumb-down",
"id": "missingTheInformationINeed",
"label":"缺少我需要的資訊"
},{
"type": "thumb-down",
"id": "tooComplicatedTooManySteps",
"label":"過於複雜/步驟過多"
},{
"type": "thumb-down",
"id": "outOfDate",
"label":"過時"
},{
"type": "thumb-down",
"id": "translationIssue",
"label":"翻譯問題"
},{
"type": "thumb-down",
"id": "samplesCodeIssue",
"label":"示例/程式碼問題"
},{
"type": "thumb-down",
"id": "otherDown",
"label":"其他"
}]
[{
"type": "thumb-up",
"id": "easyToUnderstand",
"label":"容易理解"
},{
"type": "thumb-up",
"id": "solvedMyProblem",
"label":"確實解決了我的問題"
},{
"type": "thumb-up",
"id": "otherUp",
"label":"其他"
}]
{"lastModified": "\u4e0a\u6b21\u66f4\u65b0\u6642\u9593\uff1a2015-09-01 (\u4e16\u754c\u6a19\u6e96\u6642\u9593)\u3002"}
[[["容易理解","easyToUnderstand","thumb-up"],["確實解決了我的問題","solvedMyProblem","thumb-up"],["其他","otherUp","thumb-up"]],[["缺少我需要的資訊","missingTheInformationINeed","thumb-down"],["過於複雜/步驟過多","tooComplicatedTooManySteps","thumb-down"],["過時","outOfDate","thumb-down"],["翻譯問題","translationIssue","thumb-down"],["示例/程式碼問題","samplesCodeIssue","thumb-down"],["其他","otherDown","thumb-down"]],["上次更新時間:2015-09-01 (世界標準時間)。"]]