Template:Yesno
This template is used on 6,200,000+ pages. To avoid large-scale disruption and unnecessary server load, any changes to it should first be tested in its /sandbox or /testcases subpages or in your own user subpage. The tested changes can then be added to this page in a single edit. Please consider discussing any changes on the talk page before implementing them. |
This template normalises an input to be a yes/no output.
Usage
The template distinguishes five different types of input, supplied on the first unnamed parameter:
- Yes: Case-insensitive forms of "Yes", "y" and "1"; e.g. Script error: No such module "Tlg".
- No: Case-insensitive forms of "No", "n" and "0"; e.g. Script error: No such module "Tlg".
- Nothing: When the input is defined but either contains no value or consists of whitespace character only; i.e. Script error: No such module "Tlg". or Script error: No such module "Tlg".
- Negation: When the input is either "¬" or entirely missing; i.e. Script error: No such module "Tlg". or Script error: No such module "Tlg".
- Anything else: e.g. Script error: No such module "Tlg".
By default, the template returns "yes" in the first and last case but returns blank in the other cases.
Customizing the output
Template's default output can be customized with five named parameters, respectively: |yes=
, |no=
, |blank=
, |¬=
and |def=
. If these parameters are specified, the template response is as follows:
- Yes: Template returns the contents of
|yes=
, otherwise returns "yes". For example: - No: Template returns the contents of
|no=
, otherwise returns blank. For example: - Nothing: Template returns the contents of
|blank=
or|no=
in absence of the former; otherwise, returns blank. - Negation: Template returns the contents of
|¬=
, otherwise returns blank. For example:{{yesno|¬|¬=sausage}}
results in "sausage"
- Anything else: Template returns the contents of
|def=
or|yes=
in absence of the former; otherwise, returns "yes".
For the named parameters, use of a blank value is not the same as omitting the parameter. Blank named parameters tells the template that the customized return value is blank. For example:
{{yesno|purple monkey dish washer}}
results in "yes"{{yesno|purple monkey dish washer|def=}}
results in ""
Logical distinctions
Overview of {{yesno}} logical values and their associated texts
| ||||||
---|---|---|---|---|---|---|
Input parameter 1 (<syntaxhighlight lang="text" class="" id="" style="" inline="1">1=</syntaxhighlight>) |
In code | Logical return value | Default return text |
Return text when set: <syntaxhighlight lang="text" class="" id="" style="" inline="1">yes=Pos</syntaxhighlight> <syntaxhighlight lang="text" class="" id="" style="" inline="1">no=Neg</syntaxhighlight> <syntaxhighlight lang="text" class="" id="" style="" inline="1">blank=Blank</syntaxhighlight> <syntaxhighlight lang="text" class="" id="" style="" inline="1">¬=Undefined</syntaxhighlight> <syntaxhighlight lang="text" class="" id="" style="" inline="1">def=Def</syntaxhighlight> |
Note | |
yes, y, 1* | <syntaxhighlight lang="text" class="" id="" style="" inline="1">{{yesno|yes}}</syntaxhighlight> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">yes by definition</syntaxhighlight> | "yes" | "Pos" | * Case-insensitive (Y=y) | |
Some Text | <syntaxhighlight lang="text" class="" id="" style="" inline="1">{{yesno|Some Text}}</syntaxhighlight> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">yes by default</syntaxhighlight> | "yes" | "Def" | "Pos" when <syntaxhighlight lang="text" class="" id="" style="" inline="1">def=<omitted></syntaxhighlight> | |
no, n, 0* | <syntaxhighlight lang="text" class="" id="" style="" inline="1">{{yesno|no}}</syntaxhighlight> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">no by definition</syntaxhighlight> | "" | "Neg" | * Case-insensitive (N=n) | |
<blank> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">{{yesno|}}</syntaxhighlight> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">blank</syntaxhighlight> | "" | "Blank" | "Neg" when <syntaxhighlight lang="text" class="" id="" style="" inline="1">blank=<omitted></syntaxhighlight> | |
1=<blank> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">{{yesno|1=}}</syntaxhighlight> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">blank</syntaxhighlight> | "" | "Blank" | "Neg" when <syntaxhighlight lang="text" class="" id="" style="" inline="1">blank=<omitted></syntaxhighlight> | |
¬ | <syntaxhighlight lang="text" class="" id="" style="" inline="1">{{yesno|¬}}</syntaxhighlight> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">¬</syntaxhighlight> | "" | "Undefined" | ||
<omitted> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">{{yesno}}</syntaxhighlight> | <syntaxhighlight lang="text" class="" id="" style="" inline="1">¬</syntaxhighlight> | "" | "Undefined" |
Full parameter list
Unnamed parameter 1= the input value to be evaluated. The other parameters (all named, all optional), are the return values for their respective logical outcome. When set, each one overrules their default return value.
{{yesno | | yes = | no = | blank= | ¬ = | def = }}
TemplateData
TemplateData for Yesno
This template normalises an input to be a yes/no output.
Parameter | Description | Type | Status | |
---|---|---|---|---|
Input value | 1 | The value to be evaluated | String | required |
Output on yes | yes | Specifies the output of the template when the input value is a case-insensitive forms of 'Yes', 'Y' or '1' | String | optional |
Output on no | no | Specifies the output of the template when the input value is a case-insensitive forms of 'No', 'N' or '0' | String | optional |
Output on blank input | blank | Specifies the output of the template when the input value is defined but is either empty or contains nothing but whitespace character(s) | String | optional |
Output on ¬ | ¬ | Specifies the output of the template when the input value is either '¬' or entirely missing (undefined) | String | optional |
Definite output | def | Specifies the output of the template when the input value is defined but not a form of 'yes', 'no', '1', '0', '¬' or blank | String | optional |
id:Templat:Yesno sl:Predloga:Yesno
The above documentation is transcluded from Template:Yesno/doc. (edit | history) Editors can experiment in this template's sandbox (edit | diff) and testcases (create) pages. Please add categories to the /doc subpage. Subpages of this template. |