Help:Templates

Templates enable you to do things much faster and/or easier. Templates are used very frequently on pages, so it's best to learn about them. When the website sees a template it recognizes on a page, it will automatically replace it with something else. What appears there is up to the users.

How to use a template
Before a template can be added somewhere, first its contents must be defined on its own page. Template pages should start with the prefix.

Templates have some limited programming abilities, which gives them lots of possibilities. We'll talk more about those later.

To add a template to a page (which is called transcluding), simply type, the name of the template, and then. If you wish to add any parameters, put a  between the template's name and the , and define the parameters there. All parameters you define need to be separated by another.

Examples
Here's a template where we don't define any parameters, you just drop it right in. Result:

If you visit this template's page, you'll see that its just those five words.

Template:cl can accept up to two unnamed parameters. Result:

Unnamed parameters must be defined in a specific order.

Template:KIO is one of the most common templates used. It accepts an optional named parameter.

Result:

Without the  at the end, the (available in all games since ) message would not have displayed. Named parameters can be defined in any order. Unnamed parameters may also be defined this way, such as:.

Templates can also use templates.

Substitution
Instead of transcluding a template, one can choose to substitute it. Substitution will replace a template with the contents of the template directly onto the page. To substitute a template, transclude it like you normally would, then add  between   and the template's name. After that, click the save button and the wikitext will automatically be added.

Do not substitute carelessly, because the substituted wikitext will not be updated when the template is. See Wikipedia:Help:Substitution for more information. This is a bad page. When the page is saved, that text will be replaced with this: Note the automatic forwarding of parameters. When substituting, usually the page will not appear any differently than it would if transcluded. The only difference is in the page code.

Advanced substituting
If  is wrapped in   tags, whatever is being substituted will only be substituted on the transclusion. This requires that the page as a whole be transcluded, or the subst'ed part will actually display as if it were wrapped in  tags. This technique is used by Template:Date and Source Entities:Stats/t.

Making templates
Making a template like Template:Restart is rather easy - just type the text you want, and save it. What about ones with parameters?

Unnamed parameters
To add an unnamed parameter, simply put  where you want it to be.

Here's (basically) the code for Template:Tip: Tip: If you've seen this template before you know that there's more to it, but this is all we need to look at for now. All the user has to do when transcluding this is enter the text they want: Result:

If you want to add more than one unnamed parameter, simply change the number. Here's some (condensed) code for Template:KIO: ;

This template has some things we haven't talked about yet, but you can still see that there's three unnamed parameters used:,  , and.

All the user has to do when transcluding is this: Result:

Named parameters
Named parameters can be useful too as they can be defined in any order, and can be easier to understand, however they do take longer to type. In Template:Oldnote,  marks a place to add wikitext that's defined by   when transcluding.

With named parameter: Result:

Without named parameter: Result:

Default value
To make a parameter have a value by default, add a  to the right of the parameter name, and then define the value. Named and unnamed parameters can use this. This would make the value for. This returns ", it would literally return "" as text, if it hasn't already been assigned a value at some other point.

Parser Functions
checks if a string or parameter has anything inside it. Result: (The parameter   returns null because you (probably) are not viewing this page through a transclusion, so it's never had a chance to be defined.) Result:

checks for equality between two strings. It can be used with parameters as well. Result: Result:

solves math problems. Result:

See m:Help:Calculation for all it's abilities.

tells if a math expression is correct. Result: Result:

Documentation
Please give a description of what your template is, and maybe examples. To keep this describing text from appearing on pages, there are 3 different HTML tags you can use.

keeps wikitext inside it from appearing on the destination page, while keeping it on the source page.

makes only wikitext inside it appear on destination pages. Text not inside these will still appear on the template's page.

wikitext inside this will not appear on the template page. It has no effect on the destination page however.

They can sound very confusing at first. If you're confused on how to use them, check the source code for a template, because almost all use them for one purpose or another. If a template's purpose can be understood with a quick glance, skip the documentation.

Templates not updating
If you've recently edited a template and the changes are not applying on pages it's been transcluded to, add  at the end of the URL for those pages. This will tell the server to update the page's HTML immediately. You can achieve the same effect by editing a page and saving it without making any changes.

Miscellaneous
These things are not templates, but are closely related.

Forces the table of contents to be placed at this spot.

Forces the table of contents to be placed at its normal spot. (Only useful on pages that don't have enough sections to automatically display a TOC.)

Hides the table of contents.

Marks a category as hidden. To make the website show hidden categories for you, check the Show hidden categories box in Special:Preferences.

Changes the title of a page at the top bar only.

Prints the name of the page.

Note about Module namespace
Pages in the  namespace are Lua scripts that can do some more advanced things than wikitext templates are capable of. These are allowed on SE, but it would be preferred to avoid them, so that editors don't have to learn Lua just to edit templates.