• Home
  • Random
  • Log in
  • Settings
  • About Azupedia
  • Disclaimers
Azupedia

Template:If empty

  • Language
  • Watch
  • View source
Template documentation[view] [edit] [history] [purge]
Redirects
  • {{Ifempty}}
  • {{First nonempty}}
  • {{Use first nonempty}}
Lua logoLuaModuleを使用しています:
  • Module:If empty
この記事は、クリエイティブ・コモンズ・表示・継承ライセンス3.0のもとで公表されたウィキペディアの項目Template:If emptyを素材として二次利用しています。
Lua error in Module:Itemnumber at line 91: attempt to concatenate local 'qid' (a nil value).

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. 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".

Contents

  • 1 Rationale
    • 1.1 Piping
  • 2 Examples
  • 3 See also

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, {{if empty}} produces the simpler syntax (as above):

{{if empty |{{{logo|}}} |{{{image|}}} |{{{picture|}}} |default.svg}}

Piping

Parameters used with {{if empty}} must be piped – i.e. include the vertical bar (pipe) symbol (" | ") 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 {{{logo}}}, {{{image}}} and {{{picture}}} in the above examples.

Examples

Code Result
{{if empty}} Returns an empty string.
{{if empty|one}} Returns the first parameter that is defined and not empty.
{{if empty|one|two}}
{{if empty|one|two|three|four}}
{{if empty||two}} The first parameter is empty/undefined, so is passed over.
{{if empty||two|three|four}}
{{if empty||two||four}}
{{if empty||||||||||ten}} Unlike in previous versions, this template is no longer limited by 9 parameters.
{{if empty|}} The only parameter is empty or undefined, so returns an empty string.
{{if empty||||}} Returns an empty string.
{{if empty|{{{1|}}}|{{{2|}}}|three}}
{{if empty|{{{1}}}|{{{2}}}|three}} No pipe-characters following the names of the first two parameters ("1" and "2"), so the first of these returned as text ("{{{1}}}").
{{if empty|{{{logo|}}}|two}}
{{if empty|{{{logo}}}|two}} No pipe-character following the parameter name "logo", so the text "{{{logo}}}" returned.
{{if empty|p=q}} The template identifies the parameters it receives as parameters 1 to 9, not using names such as "p", etc.

See also

  • {{if all}}
  • {{if either}}
  • {{firstdata}}
  • Help:Parameter default
The above documentation is transcluded from Template:If empty/doc. (edit | history)
Editors can experiment in this template's sandbox (create | mirror) and testcases (create) pages.
Add categories to the /doc subpage. Subpages of this template.
Retrieved from "https://wiki.tiffa.net/w/index.php?title=Template:If_empty&oldid=1001"
Last edited on 7 February 2021, at 19:13

Languages

      This page is not available in other languages.

      Azupedia
      • This page was last edited on 7 February 2021, at 19:13.
      • Content is available under Creative Commons Attribution-ShareAlike unless otherwise noted.
      • Privacy policy
      • About Azupedia
      • Disclaimers
      • Desktop