Substitution is a different way of handling templates than normally done on Wikipedia. Usually, templates are transcluded, which means that if the template changes, every page that uses it will change to match. This is the procedure used for most templates. However, some templates are instead substituted. This means that if the template changes, the page that uses it will not, and will continue to show the old version of the template. Some templates should always be substituted, while most should always be transcluded.

To substitute, add subst: after the opening braces, as in ((subst:page name)). For example: substitution ((subst:Medicine)) in contrast to transclusion ((Medicine)). The contents of page "Medicine" will be expanded (for any templates) and stored at each point where "((subst:Medicine))" is placed in a page. Note that ref-tags refuse to run "subst:" unless temporarily renamed as "<xref name=xx>" or similar.

This page also lists templates that should either always or never be substituted except in the Wikipedia namespace. Automated tools (a.k.a. bots) that do such replacements will never be used on the original template. If you are going to use a bot to substitute templates, please read through the talk page first, as many are under dispute or change status over time, and substitution is permanent.

About subst

[édit sumber]

Definition

[édit sumber]

The subst: keyword (short for "substitution") is used as a prefix inside template code. It changes the way the software expands the template. Ordinarily, a template will be expanded "on the fly"; that is, the template code on a page calls a separate page every time it is rendered. Although most page views are served from the cache, pages need to be rendered for previews, and rendered again when the page changes. When someone is editing a page with a normal template call, they see the template call. Placing "subst:" inside the curly brackets tells the software to permanently replace the template with the text of the template (i.e., the text that is on the template's article page when the template is added to the page). Therefore ((template)) becomes ((subst:template)), until you save the page. The next editor sees not the template call, but the text of the template when you saved; it does not change even if the template is edited.

Usage

[édit sumber]

You can subst a template tag by adding "subst:" to a template tag. For example, use ((subst:test5)) instead of ((test5)).

When this is a major component of an edit, it is strongly suggested that the template be mentioned in the edit summary (for instance, put "((subst:test))", "subst:test" or "test1 applied" in your edit summary) so other editors can easily see what you have done.

Additionally, when creating or editing templates that are commonly substituted, adding an HTML comment to the template page helps article editors to see how templates are being used (e.g. <!-- Substituted from Template:Documentation -->).

Benefits

[édit sumber]

Drawbacks

[édit sumber]

Templates that should always be substituted

[édit sumber]

This is a list of templates that should always be substituted, organized by namespace. Each list is ordered alphabetically with grouped series. This is not a comprehensive list, other less-used templates may also need to be substituted, see the template's documentation for details.

Article namespace

[édit sumber]

Article talk

[édit sumber]

User talk namespace

[édit sumber]

All of the templates listed in Category:User warning templates and Category:Welcome templates, as well as the user talk page component of Template:Shoutbox sidebar (and its predecessor Template:Shoutbox), should be substituted. This does not apply to templates on the user page.

File namespace

[édit sumber]

(none listed)

Misc. templates

[édit sumber]

Uncategorised suggestions

[édit sumber]

Templates that must be substituted

[édit sumber]

These templates have a purpose and/or syntax that require them to be substituted.

Templates that should not be substituted

[édit sumber]

Technically, templates shall not be substituted that

(a) contain calls to ParserFunctions (#if, #switch, etc.), unless, where possible, these are substituted too (see mw:Manual:Substitution#Multilevel substitution)
(b) template calls that do leave some parameters to their defaults by not specifying them, unless the alternative default mechanism is used
because those constructs are not replaced in the generated wiki-code (Single level substing of case (a) leaves the #if or #switch constructs verbatim at the subst location and (b) leaves constructs like "(({1|default value))}").
If specific consensus is to eliminate a particular call of such a template, Special:ExpandTemplates can be used to expand that call to plain wiki-syntax.
(c) templates that contain external links as the formatting of the URL to perform queries or look-ups may change.

List

[édit sumber]

This is a list of templates that should not be substituted. This is because they contain formatting standard code, contain complex code, or contain code that breaks if substituted.

Wrong title templates

[édit sumber]

These templates—used in the main-space—add a comment about why an article is misnamed. They may be removed as the MediaWiki titling facilities improve, and the wording/layout may change.

Chemical abbreviations

[édit sumber]

See Category:Chemical element symbol templates. These are used to simplify the entry of chemical formulae.

[édit sumber]

Most templates related to renaming or deleting pages are used temporarily, and thus do not need to be substituted (it just makes more work to delete them).

Exceptions: The following templates must be substituted in order to work correctly:

In addition, those templates which document a finished deletion process (((afd top)), etc.) should be substituted.

Under debate

[édit sumber]

See also

[édit sumber]

Citakan:Wikipedia glossary