Home Web Front-end H5 Tutorial html5的history API

html5的history API

Nov 22, 2016 pm 01:51 PM
html5

I have to admire the Google Chrome team for using HTML5 and CSS3 to implement a very beautiful online e-book: "20 Things About Browsers and the Internet".

Visit address: http://www.20thingsilearned.com

It has been a long time since this e-book was released, but I still like it after reading it today. We can switch e-book pages back and forth without refreshing the page, which is the perfect embodiment of OPOA (One Page One Application).

I am currently learning about the history API, so I am particularly interested in how they use window.history.pushState() and window.history.replaceState() to switch between pages without refreshing.

I checked some information today and basically have a basic understanding of the history API.

The first thing to say is that history is the overall situation, that is, window.history. You must be familiar with this variable name, because you can often see the JavaScript code using window.history.back() or window.history.go(-1) to return the previous page.

So history is not a new thing. In the era of HTML4, we can use these attributes and methods of it:

length: the number of records in the history stack.

back(): Return to the previous page.

forward(): Forward to the next page.

go([delta]): delta is a number. If it is not written or is 0, refresh this page; if it is a positive number, it will advance to the corresponding number of pages; if it is a negative number, it will go back to the corresponding number of pages.

Now, HTML5 adds the following 2 methods:

pushState(data, title [, url]): Add a record to the top of the history stack. data is an object or null, which will be passed as the state attribute of the parameter when the window's popstate event (window.onpopstate) is triggered; title is the title of the page, but all current browsers ignore this parameter; url is the page's URL, if not written, it will be the current page.

replaceState(data, title [, url]): Change the history of the current page. The parameters are the same as above. This change does not access the URL. However, it is currently only supported by Safari 5.0+, Chrome 8.0+, Firefox 4.0+ and iOS 4.2.1+. If you want to be compatible with old browsers, you can try History.js, and it also fixes some bugs.

Of course, on mobile platforms, we can boldly try the history API of html5. The built-in browsers of ios3.0+ and Android2.0+ platforms are perfect for history. Using it, we can make web apps more like native apps.

Below, I recommend a few articles:

.Manipulating the browser history

.Session history and navigation

.Manipulating History for Fun & Profit


Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Table Border in HTML Table Border in HTML Sep 04, 2024 pm 04:49 PM

Guide to Table Border in HTML. Here we discuss multiple ways for defining table-border with examples of the Table Border in HTML.

HTML margin-left HTML margin-left Sep 04, 2024 pm 04:48 PM

Guide to HTML margin-left. Here we discuss a brief overview on HTML margin-left and its Examples along with its Code Implementation.

Nested Table in HTML Nested Table in HTML Sep 04, 2024 pm 04:49 PM

This is a guide to Nested Table in HTML. Here we discuss how to create a table within the table along with the respective examples.

HTML Table Layout HTML Table Layout Sep 04, 2024 pm 04:54 PM

Guide to HTML Table Layout. Here we discuss the Values of HTML Table Layout along with the examples and outputs n detail.

HTML Input Placeholder HTML Input Placeholder Sep 04, 2024 pm 04:54 PM

Guide to HTML Input Placeholder. Here we discuss the Examples of HTML Input Placeholder along with the codes and outputs.

Moving Text in HTML Moving Text in HTML Sep 04, 2024 pm 04:45 PM

Guide to Moving Text in HTML. Here we discuss an introduction, how marquee tag work with syntax and examples to implement.

HTML Ordered List HTML Ordered List Sep 04, 2024 pm 04:43 PM

Guide to the HTML Ordered List. Here we also discuss introduction of HTML Ordered list and types along with their example respectively

HTML onclick Button HTML onclick Button Sep 04, 2024 pm 04:49 PM

Guide to HTML onclick Button. Here we discuss their introduction, working, examples and onclick Event in various events respectively.

See all articles