跳转到内容

帮助:替換引用

本页使用了标题或全文手工转换
来自维基学院
这是元维基上帮助文档副本的中文翻译,请参看元维基上的帮助文档后再修改本文。

本文在元维基的原文是:meta:Help:Substitution



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

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

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

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

样例: Template:Tim,包含[[:Template:T2]],以{{subst:t2|[[a]]|{{tc}}}}方式引用,得到源代码start_[[a]]_middle_{{tc}}_end,显示为start_a_middle_Template:Tc_end。

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

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

如果你想修改替换引用生成的目标代码,你必须先保存,因为预览时替换引用还没发生,替换引用只在保存时发生。

另一种方式就是手动替换,复制模板的源代码再编辑。另一种方式是使用“msgnw:”修饰符(参见:Help:模板#msgnw)。

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

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

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

得到:

2024年12月21日, 16:38 (UTC)

解析函数

[编辑 | 编辑源代码]

对解析函数的替换引用与模板一样,但是“subst:”与“#”之间不能有分隔。例如:

{{subst:#time:c}}

得到 2012-02-08T08:08:32+00:00

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

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

使用限制

[编辑 | 编辑源代码]

模板內部如果嵌入了引用替换方式的其它模板或者有引用替换效果的簽名~~~、~~~~、~~~~~時,模板自身也只能以引用替換的方式使用,即以{{subst:模板名|相关参数}}的方式来使用模板。比如模板A裡包含了

這是一個關於{{<includeonly>subst:</includeonly>B}}的例子

那麼,只能這樣使用模板A:

{{subst:A}}

其他修饰符

[编辑 | 编辑源代码]

自动产生模板的源代码。

safesubst

[编辑 | 编辑源代码]

用于同时替换引用和嵌套的模板。