Flying Pages by WP Speed Matters


Flying Pages preload pages before the user click on it, making them load instantly

Quick Links

How it Works?

Flying Pages injects a tiny JavaScript code (1KB gzipped), waits until the browser becomes idle. Then it detects pages in the viewport and on mouse hover and preloads them.

Flying Pages is intelligent to make sure preloading doesn’t crash your server or make it slow.

  • Preload pages in the viewport – Detect links within the viewport (current viewing area) using ‘Intersection Observer’ and tells the browser to preload them using ‘prefetch’, switch to xhr if not available (similar to Quicklink).

  • Preload pages on mouse hover – On hovering links, if it’s not preloaded yet using above ‘viewport’, then Flying Pages will prefetch them instantly (similar to

  • Limits the number of preloads per second – If your page has too many links, prefetching all at the same time will cause the server to crash or slow down the website to visitors. Flying Pages limits the number of preloads per second (3 req/sec by default) using an in-built queue. For example, if you’ve 10 links in the viewport, preloading all these are span into 4 seconds.

  • Stops preloading if the server is busy – In case the server starts to respond slowly or return errors, preloading will be stopped to reduce the server load.

  • Understands user’s connection and preferences – Checks if the user is on a slow connection like 2G or has enabled data-saver. Flying Pages won’t preload anything in this case.

Screenshot (schermate di esempio)

  • Flying Pages Settings


From within WordPress

  1. Visit ‘Plugins > Add New’
  2. Search for ‘Flying Pages’
  3. Activate Flying Pages for WordPress from your Plugins page.
  4. Visit ‘Settings -> Flying Pages’ to configure


  1. Upload the flying-pages folder to the /wp-content/plugins/ directory
  2. Activate the Flying Pages plugin through the ‘Plugins’ menu in WordPress
  3. Visit ‘Settings -> Flying Pages’ to configure


My GTmetrix fully load time increased after installing Flying Pages. What to do?

Flying Pages starts preloading when all other resources have completed downloading and browser has become idle. It will not affect the TTFB or First Contentful Paint or Time to Interactive. If you’re worried about the fully loaded time in GTmetrix, set the “Delay to start preloading” to a higher number in settings or set it to preload only on mouse hover.

How to check if Flying Pages is working or not?

See the video and you’ll find ‘prefetch cache’ (test it from an incognito window if you’ve enabled ‘Disable for logged in admins’)

I’m not seeing any improvements in GTmetrix/Pingdom/Google PageSpeed Insights

Flying Pages preload links after the website is loaded and only improves the speed on clicking links. It doesn’t help you to speed up the initial load.

Do I need a cache plugin?

Every time a page/link is preloaded, it executes some PHP code and MySQL queries which is resource-intensive. So it’s highly recommended to use a cache plugin like WP Rocket.

Recommended hosting provider & cache plugin?

Flying Pages works with every hosting provider, without any cache plugins. However, to get the best results, consistent performance and no downtime, our recommended hosting provider is Cloudways and cache plugin WP Rocket.

Do Flying Pages affect Google Analytics or similar tracking scripts?

Flying Pages only downloads the HTML content. It doesn’t execute any code inside it. So it will not affect Google Analytics or similar scripts.

Will Flying Pages increase my bandwidth usage?

It’s mostly videos and images that consume 80% of the bandwidth. Flying Pages only preloads HTML pages (which is usually <30KB) and doesn’t download any resources inside it (like images, css, js). Installing Flying Pages won’t increase your bandwidth usage not even by 5%.

Do Flying Pages increase server load?

In short, yes. But you can configure Flying Pages to limit the number of preloads per second or preload only on mouse hover which reduces the server load. Also, make sure to use a good hosting provider like Cloudways and a cache plugin like WP Rocket. This will reduce server load dramatically.

How to get support?

Please create a support request in the official support forum. You can also get help from WP Speed Matters’ Facebook group.


12 Marzo 2020
It surprises me just how much this works, it's almost like a magic bullet to increase your overall load time. Now I haven't done a complete stress test of it yet but with how its performing right now, I've no doubt it will deliver. When you click on any element in your site, it just loads, it kind of reminds me of React in some respects. Though don't expect Single Page App experience, that's still not the case here, it's just really fast, or maybe the illusion of being fast. Your site will still be slow if you add too much bloat on it, so be wary of that.
10 Gennaio 2020
Currently, there is a lot of discussion about scoring on speed test sites but we leave aside something as simple as the user experience. This plugin with small processing sacrifice, we can drastically increase the reader experience. I already consider your blog an essential reading, I see that your plugins too ! Atualmente, se discute muito sobre a pontuação em sites de teste de velocidade mas deixamos de lado algo simples como a experiência do usuário. Esse plugin com sacrificio pequeno de processamento, podemos aumentar drasticamente a experiência do leitor. Já considerava seu blog uma leitura obrigatória hahaha vejo que seus plugins também !
7 Gennaio 2020
Great Plugin with excellent customer support.
Leggi tutte le recensioni di 40

Contributi e sviluppo

“Flying Pages by WP Speed Matters” è un software open source. Le persone che hanno contribuito allo sviluppo di questo plugin sono indicate di seguito.


“Flying Pages by WP Speed Matters” è stato tradotto in 3 lingue. Grazie ai traduttori per i loro contributi.

Traduci “Flying Pages by WP Speed Matters” nella tua lingua.

Ti interessa lo sviluppo?

Esplora il Codice segui il Repository SVN iscriviti al Log delle Modifiche. Puoi farlo tramite RSS con un lettore di feed.

Changelog (registro delle modifiche)


  • [BUGFIX] Warnings and errors in Compatibility tab


  • [NEW] Compatibility tab


  • [BUGFIX] Stopped preloading when ignore list is empty
  • [NEW] FAQ
  • [NEW] Optimize more


  • Bug fix for Fast Velocity Minify plugin


  • Addtional options to mouse hover delay (0ms) and max rps (2s)
  • Disable for logged in admins by default


  • Moved option’s config object to window
  • Separate option for ‘preload only on mouse hover’
  • Start flyingPages() without waiting for DOMContentLoaded
  • Improved babel setup
  • Removed arrow functions for IE compatibility


  • Removed XMLHttpRequest and improved minification of JS file (reduce size by ~300bytes)
  • Added option ‘2 secs’ to delay to start preloading


  • Changing JavaScript scope to prevent conflicts with other plugins using same variables


  • Option to disable preloading when logged in as administrator


  • Disable on Internet Explorer
  • Renamed observer object to prevent conflicts with other plugins


  • Ignore query strings by default


  • Allow 1 second in delay


  • Better compatibility for WooCommerce
  • Prefetching on mobile using ‘touchstart’


  • Bug fix – Start queue only after calling main function, causing errors in browser console


  • Bug fix – Issues with Swift Performance cache plugin when ‘Merge Scripts’ is enabled


  • Bug fix – Prevent max rps from resetting to default value on plugin update


  • Support WordPress 4.5+
  • Copy fixes


  • Bug fix – Set default config on plugin update/activation


* Configure ignore keywords
* Configure delay for prefetching from viewport
* Configure to prefetch on mouse hover only
* Configure maximum requests per second
* Configure mouse hover delay


  • Bug fix – Prevent wp-admin links from preloading


  • Bug fix for Safari/iOS Safari


  • Prevent logout links from preloading


  • Prevent external links from preloading on hover


  • Support for Microsoft Edge browser
  • Prevents current page from preloading


  • Initial release