FANDOM


修飾符「subst:」(「substitute」,「替代」)位於模板、變量、解析函數的「{{」之後。但subst對參數的「{{{」不起作用。

它能在引用頁面儲存時,將維基代碼自動替換,分別為︰

  • 模板的維基代碼,而不是引用模板的維基代碼(例如{{template1}}),參數被替換成參數的值;
  • 變量的值;
  • 解析函數的值。

對模板的替換引用不會顯示在頁面歷史和模板的鏈入頁面等中。

模板编辑

樣例︰ Template:t2討論 - 鏈入頁面 - 編輯),包含<noinclude>{{Sample}}[[Category:輔助模板]]</noinclude>start_{{{1}}}_middle_{{{2}}}_end,以{{subst:t2|[[a]]|{{x2|b}}}}模式引用,得到原代碼start_[[a]]_middle_{{x2|b}}_end,顯示為start_a_middle_

0_end。

注意到這種對模板的替換不會自動重複進行︰如果被替換引用的模板又引用了其他模板,那個模板不會被替換引用。你可以隨後加上subst,做手動轉換。這種逐步的替換引用對於分析模板調用原理很有用。但是,複雜的是︰

  • 如果參數名取決於另一個參數的預設值,那麼替換引用時這不會被計算。

如果你想修改替換引用生成的目標代碼,你必須先儲存,因為預覽時替換引用還沒發生,替換引用只在儲存時發生。

另一種模式就是手動替換,複製模板的原代碼再編輯。另一種模式是使用「msgnw:」修飾符(參見︰Help:模板#msgnw)。

對「~~~~」進行替換引用沒有效果。

變量编辑

對變量替換引用與對模板的類似。比如時間戳︰

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

得到︰

2020年4月3日, 04:52 (UTC)

解析函數编辑

對解析函數的替換引用與模板一樣,但是「subst:」與「#」之間不能有分隔。例如︰

{{subst:#time:c}}

得到

2008-09-01T08:05:44+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}},頁面顯示出變化的當前時間04:52;
在頁面中儲存{{subst:Demo}},原檔案為{{CURRENTTIME}},頁面顯示出變化的當前時間04:52;
  • 在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裡包含了

這是一個關於{{subst:B}}的例子

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

{{subst:A}}

參見 编辑

除了特别提示,社区内容遵循CC-BY-SA 授权许可。