define
Window.history provides access to the browser’s session history, exposes a number of useful methods and properties, allows you to jump forward and backward through the user’s browsing history, and (starting with HTML5) provides manipulation of the contents of the History stack.
History properties
attribute | instructions | |
---|---|---|
length | The number of pages in the history stack. | |
state | The current page status value in the history stack. It can be retrieved from the popState event callback (event.state) or from history.state. |
The history method
methods | instructions | call |
---|---|---|
forward | The forward jump has the same effect as when the user clicks the forward button of the browser. | History.forward () // Forward one page |
back | This parameter has the same effect as when the user clicks the browser back button. | History.back () // Back one page |
go | Loads a particular page in the session history, marked by its position relative to the current page (the current page is 0). | History.go (-1) // Back a page, equivalent to calling back() History.go (1) // Forward a page, equivalent to calling forward() |
pushState | Add history. Usually withwindow.onpopstate Use together. |
|
replaceState | Example Modify the current history. Usually withwindow.onpopstate Use together. |
pushState
History. pushState(state, title, url) // Push a new history record to the top of the history stack and change the current pointer to the top.Copy the code
State: State object State is a JavaScript object and is mandatory. The popState event is triggered when the user navigates to a new state.
Title: Firefox currently ignores this parameter, but may use it in the future. You can pass an empty string, mandatory.
Url: This parameter defines a new historical URL record. Note that the browser does not load the URL immediately after calling pushState(), but it may load it later in certain circumstances, such as when the user reopens the browser. The new URL does not have to be an absolute path. If the new URL is a relative path, it is treated as relative to the current URL. The new URL must be of the same origin as the current URL, otherwise pushState() will throw an exception. This parameter is optional. The default value is the current URL.
replaceState
The parameter is the same as pushState and has the same meaning.
The difference is that replaceState modifies the current history rather than creating a new one. Note that this does not prevent it from creating a new history entry in the global browser history.
popstate
When the history changes, the PopState event is triggered. If the activated history was created by calling history.pushState() or history.replacEstate (), the state property of the popState event contains a copy of the history’s state object.
A direct call to history.pushState() or history.replacEstate () will not trigger the popState event. This event is triggered only when a browser action is taken, such as when the user clicks the browser’s forward/back buttons or calls history.forward()/history.back() in JavaScript code.
Different browsers handle popState events differently when loading a page. Chrome and Safari usually trigger a PopState event when a page loads, but Firefox does not.
The sample
Open example and type the following code on the console:
window.addEventListener('popstate'.(event) = > {
console.log("location: " + document.location + ", state: " + JSON.stringify(event.state));
});
history.pushState({page: 1}, "title 1"."? page=1");
history.pushState({page: 2}, "title 2"."? page=2");
history.replaceState({page: 3}, "title 3"."? page=3");
history.back(); // Logs "location: http://example.com/example.html?page=1, state: {"page":1}"
history.back(); // Logs "location: http://example.com/example.html, state: null"
history.go(2); // Logs "location: http://example.com/example.html?page=3, state: {"page":3}"
Copy the code
Note that although the history of the original item (http://example.com/example.html) of the unrelated state object, but later call history. The back () to activate the history study, will trigger the popstate event.
application
Use methods such as pushState to solve the problem of using Ajax to cause pages to move forward and backward.
background
-
Traditional Web development patterns
- Each operation of the user on the page triggers an HTTP request. After processing the request, the server returns an HTTP page to the client.
-
Ajax development pattern
- Ajax is a technique for updating part of a page’s data without reloading the page.
- In an Ajax application, the actions of the user on the page communicate with the server through the Ajax engine, which then submits the returned results to the Ajax engine on the client page, which then decides to insert the data into the specified location on the page.
-
Advantages & Problems
- In the Ajax development model, JavaScript can be used to update part of the data without refreshing the whole page, so as to reduce network traffic and bring better interactive experience to users.
- However, Ajax does not maintain the state of the page, that is, after moving forward or backward, the content that was previously updated through Ajax is lost.
The sample
If you want to implement such a page, the layout is as follows, and switch the navigation variable area on the left to change accordingly.
Only the variable area of the entire page is constantly changing. If the traditional Web development mode is adopted, then the title area and navigation area of the same content should be re-rendered every time the request is made, which wastes resources. Therefore, a local refresh of the variable area via Ajax is a better strategy. Since Ajax can’t maintain page state, we also have to deal with the forward and backward issues.
Therefore, two functions need to be implemented:
- Local refresh via Ajax.
- Keep Ajax updates as you move forward and back.
Implementation method:
- When the page is loaded for the first time, if there is no query address or the query address does not match, run the
history.replaceState
Change the current browser history, and then trigger the Ajax action. - Every timemanualClick on the menu on the left, and I add the Ajax address query content (
?
Appended to the demo HTML page address, usehistory.pushState
Shove it into your browser history. - Browser forward and backward will trigger
window.onpopstate
Event by bindingpopstate
Event, you can make the corresponding menu perform Ajax loading based on the query content in the current URL address, to achieve Ajax forward and backward effects.
The code is as follows:
var eleMenus = $("#choMenu a").bind("click".function(event) {
var query = this.href.split("?") [1];
if(history.pushState && query && ! $(this).hasClass(clMenuOn)) { PushState is supported & there are query characters & not click on the currently selected navigation
/* Send Ajax requests */
/ / the history
var title = "Summary of Shanghai Opening Projects in March -" + $(this).text().replace(/\d+$/."");
document.title = title;
if (event && /\d/.test(event.button)) { // The click event triggered by clicking the navigation
history.pushState({ title: title }, title, location.href.split("?") [0] + "?"+ query); }}return false;
});
var fnHashTrigger = function (target) {
var query = location.href.split("?") [1], eleTarget = target || null;
if (typeof query == "undefined") { // If there is no query character, the query character of the first navigation element is used
eleTarget = eleMenus.get(0);
history.replaceState(null.document.title, location.href.split("#") [0] + "?" + eleTarget.href.split("?") [1]) + location.hash; // https://www.zhangxinxu.com/study/201306/ajax-page-html5-history-api.html?area=pudong
fnHashTrigger(eleTarget);
} else {
eleMenus.each(function() {
if (eleTarget === null && this.href.split("?") [1] === query) {
eleTarget = this; }});if(! eleTarget) {// If there is no navigation menu for the query character, use the current navigation
history.replaceState(null.document.title, location.href.split("?") [0]);
fnHashTrigger();
} else {
$(eleTarget).trigger("click"); // Manually invoke trigger}}};if (history.pushState) {
window.addEventListener("popstate".function() {
fnHashTrigger();
});
// First load
fnHashTrigger();
}
Copy the code
Flow chart:
reference
Manipulating the browser history
Ajax vs. HTML5 History pushState/replaceState instance