Speed Up Your Website with InstantClick
TL;DR: InstantClick is a lightweight JavaScript library that makes page navigation nearly instant by preloading the linked page as soon as users hover over (or click on) a link. Learn how to install, configure, manage caching, and handle heavy resources efficiently.
Table of Contents
- Why InstantClick?
- Installation & Setup
- A Mini Demo Site to Test Speed
- Managing the Cache with InstantClick
- Preloading Heavy Resources: Tips and Precautions
- Conclusion
Why InstantClick?
Imagine you hover over a link, and while you’re just hovering, InstantClick starts downloading the target page. Then, when you actually click, the page is already in memory, making it display almost instantly. The result: faster user experience, seamless navigation, and a more fluid feel.
Advantages
- Enhanced UX: Pages appear nearly instantly on click.
- Easy Integration: One script is enough; no major site overhaul needed.
- 
History Support: Uses the pushStateAPI so your browser back/forward buttons still work correctly.
Caveats
- Scripts that run on page load (e.g., DOMContentLoaded) might need adaptation, because InstantClick may load pages “behind the scenes.”
- If you have heavy resources (large images, videos, big scripts), preloading can consume bandwidth needlessly if users never actually click the link. We’ll address how to handle that below.
Installation & Setup
- 
Download the instantclick.min.jsfile from the official site: http://instantclick.io/.
- Place it into your project folder, for example js/.
- Include the script in your HTML, then initialize InstantClick:
<script src="js/instantclick.min.js" data-no-instant></script>
<script data-no-instant>
  // Optional: Limit the cache
  InstantClick.cacheLimit = 30; 
  // Optional: Preload on hover
  InstantClick.init({
    preloadOnHover: true
  });
  // Listen for the event when navigation occurs via InstantClick
  document.addEventListener('instantclick:newPage', () => {
    console.log("New page loaded via InstantClick!");
  });
</script>
A Mini Demo Site to Test Speed
Below is a three-page mini-site you can use to test InstantClick.
Folder structure:
my-instantclick-test/
├── index.html
├── page1.html
├── page2.html
└── js/
    └── instantclick.min.js
  
  
  index.html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>InstantClick Test - Home</title>
  <style>
    body { font-family: sans-serif; margin: 20px; }
    nav ul { list-style: none; padding: 0; display: flex; gap: 10px; }
    .content { margin-top: 20px; max-width: 600px; }
    .box { background: #F0F0F0; margin: 10px 0; padding: 10px; border: 1px solid #CCC; }
  </style>
  <script src="js/instantclick.min.js" data-no-instant></script>
</head>
<body>
  <h1>Home</h1>
  <nav>
    <ul>
      <li><a href="index.html">Home</a></li>
      <li><a href="page1.html">Page 1</a></li>
      <li><a href="page2.html">Page 2</a></li>
    </ul>
  </nav>
  <div class="content">
    <p>Welcome to the home page. Hover over "Page 1" or "Page 2" to start preloading them.</p>
    <p>Then click and watch how fast they load!</p>
    <div class="box">
      <strong>Demo Content:</strong>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean euismod aliquet massa...</p>
    </div>
  </div>
  <script data-no-instant>
    InstantClick.cacheLimit = 3;
    InstantClick.init({
      preloadOnHover: true
    });
    document.addEventListener('instantclick:newPage', () => {
      console.log('New page loaded via InstantClick!');
    });
  </script>
</body>
</html>
  
  
  page1.html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>InstantClick Test - Page 1</title>
  <style>
    body { font-family: sans-serif; margin: 20px; }
    nav ul { list-style: none; padding: 0; display: flex; gap: 10px; }
    .content { margin-top: 20px; max-width: 600px; }
    .box { background: #F0F0F0; margin: 10px 0; padding: 10px; border: 1px solid #CCC; }
  </style>
  <script src="js/instantclick.min.js" data-no-instant></script>
</head>
<body>
  <h1>Page 1</h1>
  <nav>
    <ul>
      <li><a href="index.html">Home</a></li>
      <li><a href="page1.html">Page 1</a></li>
      <li><a href="page2.html">Page 2</a></li>
    </ul>
  </nav>
  <div class="content">
    <p>You are on Page 1. Try going back to Home, then come back here to see how quick it is.</p>
    <div class="box">
      <strong>Demo Content:</strong>
      <p>Curabitur at ipsum vel nunc venenatis lobortis. Vestibulum placerat nibh eget sapien accumsan...</p>
    </div>
  </div>
  <script data-no-instant>
    InstantClick.cacheLimit = 3;
    InstantClick.init({
      preloadOnHover: true
    });
    document.addEventListener('instantclick:newPage', () => {
      console.log('New page (Page 1) loaded via InstantClick!');
    });
  </script>
</body>
</html>
  
  
  page2.html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>InstantClick Test - Page 2</title>
  <style>
    body { font-family: sans-serif; margin: 20px; }
    nav ul { list-style: none; padding: 0; display: flex; gap: 10px; }
    .content { margin-top: 20px; max-width: 600px; }
    .box { background: #F0F0F0; margin: 10px 0; padding: 10px; border: 1px solid #CCC; }
  </style>
  <script src="js/instantclick.min.js" data-no-instant></script>
</head>
<body>
  <h1>Page 2</h1>
  <nav>
    <ul>
      <li><a href="index.html">Home</a></li>
      <li><a href="page1.html">Page 1</a></li>
      <li><a href="page2.html">Page 2</a></li>
    </ul>
  </nav>
  <div class="content">
    <p>Welcome to Page 2. Navigate between the three pages to test InstantClick.</p>
    <div class="box">
      <strong>Demo Content:</strong>
      <p>Sed tempus dolor ut massa viverra, nec fringilla metus facilisis. Vestibulum ante ipsum primis...</p>
    </div>
  </div>
  <script data-no-instant>
    InstantClick.cacheLimit = 3;
    InstantClick.init({
      preloadOnHover: true
    });
    document.addEventListener('instantclick:newPage', () => {
      console.log('New page (Page 2) loaded via InstantClick!');
    });
  </script>
</body>
</html>
Managing the Cache with InstantClick
- InstantClick keeps preloaded pages in memory (cache).
- By default, it can store up to 100 pages using an LRU (Least Recently Used) strategy.
- To adjust this limit, set:
  InstantClick.cacheLimit = 3; // for example
- Once a page is cached, no additional network request is made if you hover/click that link again, unless the cache limit is exceeded or the page is otherwise evicted.
Disabling Cache or Preload for Certain Links
If you don’t want to preload a certain page (especially a big one), simply add data-no-instant to the link:
<a href="heavy-page.html" data-no-instant>Heavy Page (no preloading)</a>
Preloading Heavy Resources: Tips and Precautions
If the target page has large images, videos, or big JS files:
- 
Early Preloading: With preloadOnHover: true, InstantClick starts downloading these large resources at hover time, potentially wasting bandwidth if the user never clicks.
- 
Option 1: Turn off hover preloading (default is on mousedown/touchstart):
   InstantClick.init({
     // preloadOnHover: false
   });
- 
Option 2: Mark certain links with data-no-instantto exclude them from preloading:
<a href="heavy-page.html" data-no-instant>Heavy Page (no preloading)</a>
- Option 3: Optimize resources (e.g., compress images, consider video streaming, implement lazy loading) to minimize data downloaded.
Conclusion
InstantClick is a simple yet powerful solution to provide lightning-fast navigation on your website. You only need to include one <script> and configure a few options to:
- Preload pages for instant display.
- Maintain proper browser history with pushState.
- Manage caching and choose how and when to preload (on hover or click).
- Enhance user experience — just be mindful of potential overhead when dealing with large files.
The mini demo site above helps you try and tweak the configuration for your specific setup. Happy integrating!
More Resources
- Official Docs: instantclick.io/documentation
- Examples of real-world projects using InstantClick
 

 
    
Top comments (0)