Template Tags
{exp:speedy:fragment}
{exp:speedy:fragment}
Fragment caching uses a tag pair to cache a specific block of content, as opposed to the entire page when using Static caching. You can put anything you want inside of a {exp:speedy:fragment}
tag pair, including {embed}
, {exp:channel:entries}
, or any other ExpressionEngine tag.
Parameters
disable="{if publisher:is_draft}yes|no{/if}"
Disable caching if a condition is met. (Default:""
)driver="dummy|file|redis|memcache|memcached"
The name of the cache driver you want to use for this specific instance of thefragment
cache tag. This will override the default global setting in your config.php file. If not defined, the global driver defined in$config['speedy_driver']
will be used. (Default:""
)global="yes|no"
Whether this item should be cached globally or not. Non-global items use the current url as part of their key. (Default:"no"
)key="featured_item"
The key for the item cached in this tag pair. If this key is used for a non-expired cache item, the content of that item will be used instead of parsing the content of the tag. (Required whenglobal="yes"
) (Default:"item"
)ttl="3600"
The number of seconds before this cache item with expire. If left blank the default TTL (1 hour) will be used. Usettl="0"
to cache this item until the cache it broken. (Default:""
)tags="apple|orange|etc"
A pipe-separated list of tags to apply to this item. Tags can be used in the cache breaking settings. (Default:""
)url_override="path/to/page"
Override the url used as part of the key for non-global items. (Default:""
)url_prefix="something"
Add a prefix to the key. Useful for multi-lingual sites, e.g.url_prefix="{publisher:current_language_code}"
(Default:""
)If using Publisher, and you are not displaying the default language segment in the URL, you may need a conditional similar to the
url_prefix
parameter:url_prefix="{if publisher:current_language_id != publisher:default_language_id}{publisher:current_lang_code}{/if}"
parse="inward"
This parameter is not specific to Speedy. It is available on all ExpressionEngine template tags. If you are having issues parsing a fragment that contains other{exp:module:function}
tags (either first or third party), try addingparse="inward"
to the fragment tag and it will likely resolve any parsing issues.
Example
Caching contents of channel:entries tags
When using the speedy:fragment
tag pair with an channel:entries
tag it is recommended to wrap the entire channel:entries
tag pair with a speedy:fragment
tag.
If you attempt to add multiple speedy:fragment
tags inside of a channel:entries
tag to cache the output of custom fields separately, you may not get desired results. ExpressionEngine's parser pre-parses custom fields that are tag pairs, such as any Grid, Fluid, Relationship, or Bloqs field. Thus while the cache item may be created, it will not be used on output, ExpressionEngine will re-parse the contents of the speedy:fragment
pair every time. For example:
Don't do this:
Do this:
{exp:speedy:escape}
{exp:speedy:escape}
When using fragment caching, it may be desirable to prevent certain sections of the template that are inside your {exp:speedy:fragment}
from being cached. ExpressionEngine will still parse the contents of an escape
tag every page load.
Pre-escaping
Some template variables such as {segment_*}
are always parsed before the module. For these tags we have implemented pre-escaping using a core extension.
To use pre-escaping, add a unique suffix to the tag.
Example
Template Layouts
Using ExpressionEngine's {layout}
feature works as expected if you are using the Static cache driver, or Redis with static enabled, but if you are using fragment caching you'll need to cache your layout file as a separate global cache item, and escape the {layout:contents}
tag. For example:
Then inside your template:
This technique will result in an additional cached item for each layout that is globally cached. Custom layout variable tags (e.g. anything other than {layout:contents}
) unfortunately can not be inside of an {exp:speedy:fragment}
tag in your main layout file, which means you can't use fragment caching for the entirety of your layout file, but depending on your layout file you should be able to cache the majority of it. If you need to cache your entire layout file, then static caching may be a better strategy than fragment caching.
{speedy:set_ttl}
{speedy:set_ttl}
Added in v1.7.0
Dynamically set the TTL of a fragment. Note that in this example if you are iterating over multiple channel entries, only the last occurrence of the {speedy:set_ttl}
tag will be used. The {speedy:set_ttl}
tag pair will also accept values such as "1 week", "2 months", or even a timestamp by using the {expiration_date}
variable from an entry.
{speedy:add_tag}
{speedy:add_tag}
Added in v1.7.0
Dynamically add tags to an {exp:speedy:fragment} tag pair. For example:
{exp:speedy:clear}
{exp:speedy:clear}
Use this in your templates to clear specific cache items.
Parameters
tags="apple|oranges"
Clear one or more tags and all items cached with that tag.items="local/blog/footer|local/blog/header"
clear one or more specfic cache items.
Last updated