帮助:替换引用

帮助页面

修饰符“subst:”(“substitute”,“替代”)位于模板、变量、解析函数的“{{”之后。但subst对参数的“{{{”不起作用。

它能在引用页面保存时,将wikitext自动替换,分别为:

  • 模板的wikitext,而不是引用模板的wikitext(例如{{template1}}),参数被替换成参数的值
  • 变量的值
  • 解析函数的值

对模板的替换引用不会显示在页面历史和模板的链入页面等中。

模板

注意到这种对模板的替换不会自动重复进行:如果被替换引用的模板又引用了其他模板,那个模板不会被替换引用。你可以随后加上subst,做手动转换。这种逐步的替换引用对于分析模板调用原理很有用。但是,复杂的是:

  • 如果参数名取决于另一个参数的默认值,那么替换引用时这不会被计算。

如果你想修改替换引用生成的目标代码,你必须先保存,因为预览时替换引用还没发生,替换引用只在保存时发生。但是你可以点击显示差异以显示替换引用的结果。

另一种方式就是手动替换,复制模板的源代码再编辑。

对“~~~~”进行替换引用没有效果。

变量

对变量替换引用与对模板的类似。比如时间戳:

{{subst:CURRENTYEAR}}年{{subst:CURRENTMONTHNAME}}{{subst:CURRENTDAY}}日, {{subst:CURRENTTIME}} (UTC)

得到:

2024年6月16日, 10:10 (UTC)

解析函数

对解析函数的替换引用与模板一样,但是“subst:”与“#”之间不能有分隔。例如{{subst:#time:c}}直接得到2024-06-16T10:10:01+00:00,而{{subst: #time:c}}得到{{subst: #time:c}}

nowiki与pre

如果某模板包含位于nowiki或pre标记之内的签名或替换引用,他们将被解释并展开,但nowiki或pre标记仍保留。

条件替换技术

是否进行替换可由特定参数决定,由此还可进行多重替换。原理如下:

  • 页面A包含{{subst:B|subst=subst:|参数...}}
  • template:B包含{{{{{subst|}}}C|subst={{{subst|}}}|参数...}}
  • template:C包含{{{{{subst|}}}D|subst={{{subst|}}}|参数...}}
  • 以此类推

当页面A对template:B的引用包含“subst=subst:”时,template:B对template:C的引用也是替换引用,template:C对template:D也是。若页面A不含“subst=subst:”时,便不会替换,且不会出现错误。由此,条件替换和多重替换可以实现。

基于引用的替换

在被替换的模板中使用“仅包含”和“不包含”标签,可以在引用时实现魔术般的技巧。

代码~<includeonly>~</includeonly>~~显示为~~~,当被引用时显示为~~~~,当被替换引用时展开为用户签名。而当一包含了{{<includeonly>subst:</includeonly>CURRENTTIME}}的模板被替换引用并保存时,不变的时间就被保存在维基文字中,替换了随时间变化的时间变量。变量也是如此。样例:

在Template:Demo中保存{{CURRENTTIME}},源文件为{{CURRENTTIME}}
  • 在页面中保存{{Demo}},源文件为{{Demo}},页面显示出变化的当前时间10:10;
  • 在页面中保存{{subst:Demo}},源文件为{{CURRENTTIME}},页面显示出变化的当前时间10:10。
在Template:Demo中保存{{subst:CURRENTTIME}},源文件为07:37
  • 在页面中保存{{Demo}},源文件为{{Demo}},页面显示出不变的模板保存时间07:37;
  • 在页面中保存{{subst:Demo}},源文件为07:37,页面显示出不变的模板保存时间07:37。
在Template:Demo中保存{{<includeonly>subst:</includeonly>CURRENTTIME}},源文件为{{<includeonly>subst:</includeonly>CURRENTTIME}}
  • 在页面中保存{{Demo}},源文件为{{Demo}},页面显示出{{subst:CURRENTTIME}};
  • 在页面中保存{{subst:Demo}},源文件为07:37,页面显示出不变的页面保存时间07:37。
在Template:Demo中保存{{ {{{|safesubst:}}}CURRENTTIME}},源文件为{{ {{{|safesubst:}}}CURRENTTIME}}}
  • 在页面中保存{{Demo}},源文件为{{Demo}},页面显示出变化的当前时间10:10;
  • 在页面中保存{{subst:Demo}},源文件为07:37,页面显示出不变的页面保存时间07:37。

简单的说:仅包含标签可被用于专门被替换引用的模板、变量,即在subst:前后加上仅包含标签。

使用限制

模板内部如果嵌入了引用替换方式的其它模板或者有引用替换效果的签名~~~、~~~~、~~~~~时,模板自身也只能以引用替换的方式使用。

其他修饰符

safesubst

修饰词“subst:”有可能会因故导致失败,而若失败时,修饰词“subst:”会保持未解析的状态(形如{{subst:模板名称}})而导致模板功能出现问题。若出现此种情况应该将修饰词“subst:”改为“safesubst:”修饰词,此时若替换引用发生错误则会取消替换引用变为普通的模板引用效果,来确保其他相关模板运作状况正常。此功能通常用于模板编程时,将模板内部的替换引用使用“safesubst:”修饰词,以令模板替换引用无论正常与否都能保持相同的输出。