Community -

Fresh Forms

Prevent posts and pages with a Gravity Forms shortcode or Gutenberg block from being cached.

Caching is great for scenarios where your post or page content it’s not changed frequently, but if you have a form embedded to which you do changes very often or you’re using dynamic code, that doesn’t run for a cached page, or using third-party solutions relaying in dynamic live data (e.g. reCAPTCHA), using caching in these cases is going to cause issues. The same applies to certain automatic JS optimizations done by caching plugins that are known to break JS execution easily.

An easy solution is to configure your caching plugin or proxy to exclude the page where the form is embedded, but you need also to remember this when you create a new page or embed a new form in an existing page…

This plugin will take care of the above automatically doing the following:

  • Flush current cache on plugin activation. This is required in order to allow the next step to run.
  • Dynamically check if there’s a Gravity Forms shortcode or Gutenberg block in your post (any post type) or page content using WordPress core functions for it.
  • If so, it will prevent post/page caching for supported caching plugins, browsers and CDN/Proxies.

Embedding methods supported:

  • WordPress default editor, shortcode or Gutenberg block. Content of any post type, including pages and custom posts.
  • Avada. The following elements has been proven to work: Content Boxes, “Gravity Form”, Modal, Text Block. Other elements could work too, but not tested.
  • Elementor. The following widgets added to the post content are supported: Shortcode, Text.
  • Essential Addons for Elementor Gravity Forms widget.
  • Divi. It should work with any of the default modules where you can insert a GF shortcode into the content. e.g. Call To Action, Text, Tabs…
  • WP Tools Gravity Forms Divi Module.
  • WooCommerce Gravity Forms Product Add-ons
  • ACF fields of type Text, Text Area, and WYSIWYG. Disabled by default, please see FAQ for more details.
  • Beaver Builder**. It will detect Gravity Forms shortcodes added to a Text Editor module.
  • Ultimate Addons for Beaver Builder Gravity Forms Styler module.
  • Ultimate Addons for Elementor By Brainstorm Force.
  • WPBakery Page Builder. The following elements has been proven to work: “Gravity Form”, Text Block. Other elements could work too, but not tested.

If you’re not using any of the above embedding methods you can still use Fresh Forms with a filter to pass the ID number of the posts where you want to run Fresh forms. You can also make Fresh Forms to add a cookie when a form is detected to use this cookie as a way to skip caching for hosts using Varnish based caching. Please see FAQ for more details.

There’s no options page. Only the plugin version is saved to the database to be able to handle actions after an update when needed, no other data is stored.

It should work with any caching plugin with support for DONOTCACHEPAGE constant, and proxies respecting the use Cache-Control HTTP header.

Caching plugins supported:

  • Autoptimize
  • Cache Enabler
  • Comet Cache
  • Hummingbird
  • Kinsta Cache
  • LiteSpeed Cache
  • Siteground Optimizer
  • Surge
  • W3 Total Cache
  • WP Engine System
  • WP Fastest Cache
  • WP Optimize
  • WP Super Cache
  • WP Rocket

Caching plugins NOT supported:

  • Breeze. It doesn’t support DONOTCACHEPAGE constant or filters to skip caching.
  • NitroPack. It doesn’t support DONOTCACHEPAGE constant or filters to skip caching.

CloudFlare and other proxies:

This plugin will add appropriate HTTP header to pages with a Gravity Forms form to exlude the page HTML from caching when the web host setup allows it.

By default CloudFlare doesn’t cache the page HTML, it does only when you have configured it to “Cache Everything”. In this case, after activating the plugin, you need to purge cache in your CloudFlare account or wait for cache expiration to let CloudFlare know the page must be excluded from caching.

Certain hosts like WP Engine and Kinsta don’t allow HTTP headers modification from WordPress side of things, therefore CloudFlare support will not work for these hosts.

Other proxy services should work in a similar way, but I don’t have access to test any other proxy service. Feel to reach me if you want to provide me access to add support for your proxy service (documentation for the proxy would be required).

Download This Add-On

Visit the developers website to purchase or download this third-party add-on.

Request Support

This plugin is supported by the developer on their site. We do not provide direct support for this add-on.