Template:Sp: Difference between revisions
m Changed protection level for "Template:Sp": Highly visible template ([Edit=Require template editor access] (indefinite) [Move=Require administrator access] (indefinite)) |
m 1 revision imported: More templates required for infoboxes |
||
(No difference)
|
Latest revision as of 19:44, 8 July 2024
Warning | This template is used on approximately 173,000 pages. To avoid major disruption and server load, any changes should be tested in the template's /sandbox or /testcases subpages, or in your own user subpage. The tested changes can be added to this page in a single edit. Consider discussing changes on the talk page before implementing them. |
Usage
{{sp}} will insert a single, ordinary space character, using the numeric character reference  
. It is a more readable alternative to using that code.
Anywhere you need a regular space
You can use {{sp}} anywhere you need a regular, breaking space. If you need a non-breaking space or multiple spaces in a row, use {{space}}.
Inserting a space inside a parser function
Sometimes when using parser functions, you need to insert a space at the beginning or end of an optional message. {{sp}} can be used for that purpose. In the following examples, look closely at the spacing between words and punctuation to see the subtle differences.
- Example
I like green{{#if:{{{blue|}}}|and blue}}.
The above example works fine if 'blue' does not have a value ('I like green.
').
However, if 'blue' is set to true (|blue=true
), then the message is incorrectly run together ('I like greenand blue.
').
I like green {{#if:{{{blue|}}}|and blue}}.
Adding the space between 'green' and '{{#if' avoids running the 'green and
' together, but now there will be an extra space if 'blue' is not set ('I like green .
').
I like green{{#if:{{{blue|}}}| and blue}}.
Adding the space between the pipe ('|') and the word 'and' doesn't work. Any leading or trailing spaces from a parser function output are stripped, so this produces exactly the same output as the first example when 'blue' is true ('I like greenand blue.
').
I like green{{#if:{{{blue|}}}|{{sp}}and blue}}.
This one works! By inserting the {{sp}} in the parser function output, the space is not stripped, and the correct output is given whether blue is set to true ('I like green and blue.
') or not set at all ('I like green.
').
Disabling default substitution
Suppose you have a template, {{Example}}, that uses substitution, like this:
{{{{{subst|subst:}}}#if{{{condition|}}}|message}}
When the template is transcluded and saved, the result would be interpreted as:
{{subst:#if{{{condition|}}}|message}}
You could override the substitution by setting the 'subst' attribute to {{sp}}:
{{Example| subst={{sp}} }}
Now the result would be interpreted as:
{{ #if{{{condition|}}}|message}}
The extra blank space preceding the '#if' would not affect the template at all (except to suppress the default substitution).
TemplateData
This is the TemplateData documentation for this template used by VisualEditor and other tools.
Sp
Inserts a single space character; mainly used in parser functions
Parameter | Description | Type | Status | |||
---|---|---|---|---|---|---|
No parameters specified |
See also
- {{If}} – runs the parser function
#if:
, but retains whitespace - {{fdw-iw}} – a template that uses {{sp}} with parser functions
- {{verify spelling}} – for spelling issues