onlinecode

HTML5 History API – Using the HTML5 History API

Using the HTML5 History API

HTML5 History API – Using the HTML5 History API

In this post, we will give you information about HTML5 History API. Here we will give you detail about HTML5 History API and how to use it also give you a demo for it if it is necessary.

The HTML5 History API allows you to control the browser history from JavaScript. For example, you can add entries in the history object (window.history) or set the URL of the address bar dynamically and without a full-page refresh (which means you can navigate between pages, of the same origin, without manually entering URLs and pressing Enter).

Before the HTML5 History API, developers had to use hash URLs to change the current URL (window.location="#hash") without reloading the page and create client side routing in Single Page Applications (SPAs).

Nowadys and thanks to HTML5 History API, we can create complex SPAs and fully fledged apps that run on the client side without URL hashes. Most client side libraries such as React, Vue or Angular etc. make use of the History API to create advanced routing which abstracts the inner details of this API in a high level interface that makes client side routing a breeze.

The window object has a history object that represents the browser’s history. The object provides many methods and properties that let you manipulate the user’s history jsut like you would manually do using the browser’s back and forth buttons.

The HTML5 API is available from the window.history object. You can simply open the console of your browser and type window.history which will show you the obeject and its properties:

The History object exposes many methods:

From the Developer Tools console, you can also run the methods of the HTML5 History API and see live results on your current page. Start with a new tab, open DevTools (I’m using Chrome) then activate the console panel then run the following line of JavaScript code:

history.pushState(null,null,'path');

This will add a path string to the end of the current URL https://onlinecode.org/:

Before running the previous code I have already visited https://www.onlinecode.org from the address bar.

The first parameter of the pushState() method is the data which can be passed to the new state, the second parameter is the title and the third is the URL. Note, that you can’t pass URLs with different origins from the current one, otherwise you’ll get a Same Origin Policy error that will prevent you from accessing the page. So if you run:

history.pushState(null,null,'https://www.google.com');

You will get the following error:

Uncaught DOMException: Failed to execute ‘pushState’ on ‘History’: A history state object with URL ‘https://www.google.com/’ cannot be created in a document with origin ‘https://onlinecode.org’ and URL ‘https://onlinecode.org/’.

Hope this code and post will helped you for implement HTML5 History API. if you need any help or any feedback give it in comment section or you have good idea about this post you can give it comment section. Your comment will help us for help you more and improve us. we will give you this type of more interesting post in featured also so, For more interesting post and code Keep reading our blogs

For More Info See :: laravel And github

Exit mobile version