Overview
After an initial render, markup inside a cache tag will be pulled from a cached, statically cached copy until invalidated.
{{ cache for="5 minutes" }}
{{ collection:stocks limit="5000" }}
<!-- probably lots of stuff happening -->
{{ /collection:stocks }}
{{ /cache }}
You can disable the {{ cache }}
tag (temporarily) based on the environment. This is great for your local setup.
STATAMIC_CACHE_TAGS_ENABLED=false
return [
'cache_tags_enabled' => env('STATAMIC_CACHE_TAGS_ENABLED', true), // [tl! highlight]
...
];
Exclusions
You may use the nocache
tag inside a cache
tag to keep that section dynamic.
{{ cache }}
this will be cached
{{ nocache }} this will remain dynamic {{ /nocache }}
this will also be cached
{{ /cache }}
Read more about the nocache tag
Invalidation
Caching is handy to speed up parts of your site, but it's not very useful unless it's able to be updated at some stage. Here's how
the tag contents can be invalidated.
Time
Using the for
parameter allows you to say how long the tag pair contents should be cached in time.
{{ cache for="5 minutes" }} ... {{ /cache }}
Key
By specifying a key
, you can invalidate it programmatically.
{{ cache key="homepage_stocks" }} ... {{ /cache }}
For example, you could listen for an entry in the stocks
collection being saved and then bust the key.
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\Event;
use Statamic\Events\EntrySaved;
class EventServiceProvider
{
public function boot()
{
Event::listen(function (EntrySaved $event) {
if ($event->entry->collectionHandle() === 'stocks') {
Cache::forget('homepage_stocks');
}
});
}
}
Invalidating by key
won't work if you're using tags. In that case, you should invalidate by flushing the tag.
Tag
By specifying tags
, you can invalidate it programmatically. You must be using a cache driver that supports tags, like Redis or Memcached.
{{ cache tags="stocks|home" }} ... {{ /cache }}
{{ cache tags="home" }} ... {{ /cache }}
{{ cache tags="stocks" }} ... {{ /cache }}
Similar to invalidating by a key as explained above, you can flush all keys that use the tags.
Cache::tags('home')->flush(); // invalidates first and second pair
Cache::tags('stocks')->flush(); // invalidates first and third pair
Don't use the key
and tags
parameters together.
Cache clear
The contents of your cache tags are stored in the application cache. Clear that, and you'll see fresh content next visit.
You can clear your cache using the Artisan command:
php artisan cache:clear
Tag parameters and contents
It might be useful to know that if you aren't using the key
parameter, a key is generated behind the scenes based on what
parameters and values you've used, along with what's between the tag pair.
So, if you change your template or parameters, you'll see a fresh version next time you visit the page.
Scope
The scope
parameter allows you cache the template chunk either across the whole site (the default behavior), for the current user, or per page.
For example, you might have a "recent articles" list on the sidebar that's the same on every page. Or, your footer navigation is probably the same on every page. You can use the site
scope for those.
However, your header navigation might have "active" states on it, so you'd want to make sure to cache it per page.
{{ cache scope="page" }}
{{ nav }} ... {{ /nav }}
{{ /cache }}
Or if your navigation changes depending on the current user, you want to use the user
scope:
{{ cache scope="user" }}
{{ nav }} {{ user }} ... {{ /user }} {{ /nav }}
{{ /cache }}
The scope
parameter has no effect if you use the key
parameter.
Static Caching
You're free to use the cache tag on top of static caching.
You'll probably have static caching disabled during development so you can see your changes without having to continually clear anything.
The cache tag could be a nice compromise to speed up heavy areas for a few minutes at a time. Or, if you have some pages excluded from static caching then the cache tag could be useful there.
Of course, if you do have static caching enabled, keep in mind that you aren't going to gain anything by using both at the same time.
Parameters
for
The length of time to cache this section. Use plain English to specify the length, eg. 2 hours
, 5 minutes
, etc.
key
The cache key to be used, if you'd like to manually invalidate this tag pair programmatically.
tags
The cache tags this section will be using, if you'd like to invalidate this pair programmatically. If you use this, do not also use key
.
scope
Sets the cache scope. Three possible values: site
, page
or user
. Has no effect when using the key
parameter.
store
Sets the cache store the cache tag uses to store and retrieve the cached values.