說明:替換引用

幫助頁面

修飾符「subst:」(「substitute」,「替代」)位於模板、變量、解析函數的“{{”之后。但subst对参数的“{{{」不起作用。

它能在引用頁面保存時,將wikitext自動替換,分別為:

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

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

模板

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

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

如果你想修改替換引用生成的目標代碼,你必須先保存,因為預覽時替換引用還沒發生,替換引用只在保存時發生。但是你可以點擊顯示差異以顯示替換引用的結果。

另一種方式就是手動替換,複製模板的原始碼再編輯。

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

變量

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

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

得到:

2024年6月25日, 07:01 (UTC)

解析函數

對解析函數的替換引用與模板一樣,但是「subst:」與「#」之間不能有分隔。例如{{subst:#time:c}}直接得到2024-06-25T07:01:35+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}},頁面顯示出變化的當前時間07:01;
  • 在頁面中保存{{subst:Demo}},源文件為{{CURRENTTIME}},頁面顯示出變化的當前時間07:01。
在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}},頁面顯示出變化的當前時間07:01;
  • 在頁面中保存{{subst:Demo}},源文件為07:37,頁面顯示出不變的頁面保存時間07:37。

簡單的說:僅包含標籤可被用於專門被替換引用的模板、變量,即在subst:前後加上僅包含標籤。

使用限制

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

其他修飾符

safesubst

修飾詞「subst:」有可能會因故導致失敗,而若失敗時,修飾詞「subst:」會保持未解析的狀態(形如{{subst:模板名称}})而導致模板功能出現問題。若出現此種情況應該將修飾詞「subst:」改為「safesubst:」修飾詞,此時若替換引用發生錯誤則會取消替換引用變為普通的模板引用效果,來確保其他相關模板運作狀況正常。此功能通常用於模板編程時,將模板內部的替換引用使用「safesubst:」修飾詞,以令模板替換引用無論正常與否都能保持相同的輸出。