Template:If empty: Difference between revisions
Nordic Larp Wiki>Johannes Axner m 1 revision imported |
No edit summary |
||
(One intermediate revision by the same user not shown) | |||
Line 1: | Line 1: | ||
{{<includeonly>safesubst:</includeonly>#invoke: | {{<includeonly>safesubst:</includeonly>#invoke:If_empty|main}}<noinclude>{{Documentation}}</noinclude> |
Latest revision as of 21:56, 21 October 2025
Template:Documentation subpage Template:Cascade-protected template Template:Used in system
![]() | Uses Lua: |
This template is used inside other templates. It takes any number of parameters and returns the first found to be defined and non-empty. If none is found, nothing is returned. By writing {{if empty|a|b|c}}
instead of {{#if:a|a|{{#if:b|b|c}}}}
, expression a and b do not have to be repeated and evaluated twice. The template provides a fallback order, similar to a try catch based "It is easier to ask for forgiveness than permission" (EAFP) programming style.
Typical usage is like this:
{{If empty |{{{logo|}}} |{{{image|}}} |{{{picture|}}} |default.svg}}
- — Return {{{logo|}}} if it has a value; else {{{image|}}} if it has a value; else {{{picture|}}} if it has a value; else return "default.svg".
This returns the first of the parameters logo, image and picture that is defined and non-empty, otherwise "default.svg".
Rationale
The MediaWiki parameter default function doesn't return the default value for empty parameters. That is, {{{logo|default.svg}}}
does not return "default.svg" if the template was called like this: {{template|logo=}}
.
The usual workaround for a single parameter is:
{{#if:{{{logo|}}} |{{{logo}}} |default.svg}}
- — If {{{logo}}} has a value, return it, else return "default.svg".
But this becomes complex when several parameters are to be checked:
{{#if:{{{logo|}}} |{{{logo}}} |{{#if:{{{image|}}} |{{{image}}} |{{#if:{{{picture|}}} |{{{picture}}} |default.svg}} }} }}
- — If {{{logo}}} has a value, return it; else if {{{image}}} has a value, return that; else if {{{picture}}} has a value, return that; else return "default.svg".
In these cases, Template:Tlf produces the simpler syntax (as above):
{{if empty |{{{logo|}}} |{{{image|}}} |{{{picture|}}} |default.svg}}
Piping
Parameters used with Template:Tlf must be piped – i.e. include the vertical bar (pipe) symbol Template:Nowrap as a trailing character – so that empty or undefined parameters aren't treated as text and returned incorrectly. Hence, for example, {{{logo|}}}
, {{{image|}}}
and {{{picture|}}}
rather than Template:Param, Template:Param and Template:Param in the above examples.
Examples
See also
- REDIRECT Template:Template link
![]() Template:Redirect templateTemplate:R from move/except When appropriate, protection levels are automatically sensed, described and categorized. |
- REDIRECT Template:Template link
![]() Template:Redirect templateTemplate:R from move/except When appropriate, protection levels are automatically sensed, described and categorized. |
- REDIRECT Template:Template link
![]() Template:Redirect templateTemplate:R from move/except When appropriate, protection levels are automatically sensed, described and categorized. |
- REDIRECT Template:Template link
![]() Template:Redirect templateTemplate:R from move/except When appropriate, protection levels are automatically sensed, described and categorized. |