Template:TryError/doc

来自testwiki
imported>D25138502023年11月13日 (一) 14:22的版本 範例:​嵌入已知會模板循環的Template:模板1
(差异) ←上一版本 | 最后版本 (差异) | 下一版本→ (差异)
跳转到导航 跳转到搜索

Template:NoteTA/MediaWikiTemplate:Documentation subpage Template:High-use

概要

本模板實現了try...catch...finally的結構

而若用{{#iferror:}}無法根據錯誤種類來做處不同處理,而若用嵌套解析器,對於部分高開銷操做是不利的,因此提供一個類似程式碼的方式來實現。而考量到en:Template:Try模板存在,因此仔不影響使用的情況以TryError命名。

參數及使用方法

{{TryError
|<可能有錯誤的維基代碼>
|catch(<錯誤的class>)=<發生對應錯誤的處置>
|catch=<發生通用錯誤的處置>
|finally=<無論是否錯誤都會顯示的維基代碼>
}}

模板參數

Template:TemplateDataHeader <templatedata> { "params": { "1": { "label": "可能有腳本錯誤的維基代碼", "description": "用來處理腳本錯誤的維基代碼", "example": "除以零。", "type": "string", "default": null, "autovalue": null,

           "required": false

}, "catch": { "label": "代碼出現其他錯誤的錯誤訊息", "description": "若該代碼出現其他錯誤時才會輸出該錯誤訊息", "example": "出現不明錯誤", "type": "string", "default": null, "autovalue": null,

           "required": false

}, "catch(類型)": { "label": "代碼出現特定類型錯誤的錯誤訊息", "description": "若該代碼出現某個指定類型的錯誤時才會輸出該錯誤訊息,而類型應該在括號裡指定", "example": "出現Lua腳本錯誤", "type": "string", "default": null, "autovalue": null,

           "required": false

}, "finally": { "label": "不論代碼是否有錯都一定會出現的訊息", "description": "若該代碼不論是否有錯都一定會出現的內容", "example": "內容已除錯", "type": "string", "default": null, "autovalue": null,

           "required": false

}

   },

"description": "本模板用來輸出錯誤訊息到標準輸出,實現了try...catch...finally的結構", "format": "block" } </templatedata>

範例

  • 無錯誤的維基代碼搭配try...catch:
{{TryError
|無錯誤的維基代碼
|catch=
}}

Template:TryError


  • 移除有錯誤的維基代碼:
{{TryError
|這些{{#expr:0/0}}有錯誤
|catch={{{no error}}}
}}
輸出:
Template:TryError

  • 有錯誤的維基代碼:
{{#expr:0/0}}{{link-wd|Q0/0}}
輸出:
除以零。Template:Link-wd

  • 有錯誤的維基代碼搭配try...catch:
{{TryError
|{{#expr:0/0}}{{link-wd|Q0/0}}
|catch=
}}
輸出:
Template:TryError

  • try...catch...finally
{{TryError
|{{#expr:0/0}}{{link-wd|Q0/0}}{{User 超電磁炮|level=1/0|name=零除錯誤|call=除錯}}{{Topic:Xo1mzbojtxmiusgl}}{{模板1}}
|catch=發生{{{message}}}錯誤!
|finally=結束
}}
輸出:
Template:TryError

  • try並catch 「scribunto-error」錯誤和一般catch:
{{TryError
|{{#expr:0/0}}{{link-wd|Q0/0}}
|catch(scribunto-error)=發生{{{message}}}錯誤!
|catch=發生{{{message}}}錯誤!
|finally=結束
}}
輸出:
Template:TryError

  • try並提供空的一般catch:
{{TryError
|{{#expr:0/0}}{{link-wd|Q0/0}}
|catch=
|finally=結束
}}
輸出:
Template:TryError

  • try並throw:
{{TryError
|{{#expr:0/0}}{{link-wd|Q0/0}}
|catch(scribunto-error)={{{throw}}}
|finally=結束
}}
輸出:
Template:TryError

  • try並throw其他錯誤:
{{TryError
|{{#expr:0/0}}{{link-wd|Q0/0}}
|catch(scribunto-error)={{參數|throw|foo(throw其他錯誤)}}
|finally=結束
}}
輸出:
Template:TryError

  • 巢狀try...catch:
{{TryError
|{{#expr:0/0}}{{link-wd|Q0/0}}{{TryError|{{#expr:0/0}}|catch={{參數|throw|foo(throw其他錯誤)}} }}
|catch(foo)=接到foo錯誤
|finally=結束
}}
輸出:
Template:TryError

  • 未能提供匹配的錯誤catch:
{{TryError
|{{#expr:0/0}}{{link-wd|Q0/0}}
|catch(foo)=接到foo錯誤
|finally=結束
}}
輸出:
Template:TryError

技術限制

與#iferror一樣,本模板無法處理來自擴展標籤(如<math>...</math>)的錯誤

{{#iferror:<math>\你好</math>}}
輸出
解析失败 (语法错误): {\displaystyle \你好}

{{TryError
|<math>\你好</math>
|catch={{{no error}}}
}}
輸出
Template:TryError

注意事项

模板编辑说明

參見