此模板文档基于以下Lua模块编写:
本模板通过解析器函数,可在不创建一个新的模板的情况下,动态生成一个“虚拟的”临时模板,并传入参数进去,类似于C++或java的匿名函数、Closure或者JavaScript中的立即调用函数表达式。
- 用途:在部分说明文档示范模板语法,或解协助解析条目中无法顺利被解析的模板语法。
- 用法:由于需要先回避模板语法在生成一个“虚拟的”临时模板前就被解析,因此
{{{}}}
与{{}}
皆要先由跳脱字符切割成如{\{\{}\}\}
与{\{}\}
的形式。
参数及使用方法
{{虚拟模板 | code= 填入模板語法 | ... | ... 傳入模板參數、當正常模板使用 }}
模板参数
通过解析器函数,可在不创建一个新的模板的情况下,动态生成一个“虚拟的”临时模板,并传入参数进去
参数 | 描述 | 类型 | 状态 | |
---|---|---|---|---|
1 | 1 | 传入"code"参数的的第1个参数
| 字符串 | 可选 |
code | code | 模板语法
| 字符串 | 可选 |
code语法为nowiki | delnowiki | 解析code内容中位于nowiki标签内的部分 | 布尔 | 可选 |
code语法为msgnw | delmsgnw | 解析code内容中位于msgnw内的部分 | 布尔 | 可选 |
示例
- 一般用法
- 输入
{{虚拟模板|code=在{{{1}}}中,{{{2}}}是一門{{{3}}}。 | 數學 | 微積分 | 重要的議題 }}
- 显示为“在数学中,微积分是一门重要的议题。”
- 输入
- 强制注入参数
- 输入
{{虚拟模板|code=在{{{1}}}中,{{{2}}}是一門{{{3}}}。|args={{虚拟模板|參數 | \1=物理學 | 數學 | 重要的議題 }} }}
- 显示为“在物理学中,数学是一门重要的议题。”
- 输入
- 防止提前解析
- 方法一,使用跳脱字符
- 输入
{{虚拟模板|code={\{#tag:math{{!}}\\frac{ {{{1}}} }{ {{{2}}} } }\} | 16 | 25 }}
- 显示为“<math>\frac{ 16 }{ 25 } </math>”
- 输入
- 方法二,使用
<nowiki></nowiki>
- 输入
{{虚拟模板|delnowiki=yes|code=<nowiki>{{#tag:math|\\frac{ {{{1}}} }{ {{{2}}} } }}</nowiki> | 16 | 25 }}
- 显示为“<math>\frac{ 16 }{ 25 } </math>”
- 输入
- 方法一,使用跳脱字符
- 测试间接参数传递时,特定模板语法的行为
- 输入
{{虚拟模板|delnowiki=yes|code=<nowiki>{{#invoke:ilh|main}}</nowiki> | lang=維基數據 | lang-code=d | Minecraft世界 | Q26945014 }}
- 显示为“Minecraft世界”
- Template:说明:虚拟模板内的语法为“
{{#invoke:ilh|main}}
”,当这个内容是一个独立的模板时,结果为输入参数“| lang=維基數據 | lang-code=d | Minecraft世界 | Q26945014
”的行为。
- 输入
- 作为空模板
- 还原跳脱字符
- 输入
{{虚拟模板|code=\n**:#第甲項\tAA\b\n**:#第乙項\tBB\b}}
- 显示为“
- 第甲项 AA�
- 第乙项 BB�”
- 显示为“
- 输入
- {{虚拟模板}}的传递与使用(仅在单次页面渲染有效)
- 照顺序摆放代码将有以下效果:
{{變數|set|臨時模板1=<nowiki>虚拟模板|code=順利地執行了{{{1}}}的臨時模板{{{2}}}。</nowiki>}}
Template:变数{{變數|call|臨時模板1| 1號 | 引用 }}
→“Template:变数”
- 照顺序摆放代码将有以下效果:
- 延伸用法(让模板可以自己产生内容,又能让外部调用)
- 模板内:
{{虚拟模板|code={\{#invoke:Fullurl|fullurl}\}|args=<noinclude>{{虚拟模板|參數|\1=Template:虚拟模板}}</noinclude>{{#invoke:参数|虚拟模板扩展参数}}}}
- 模板显示:Template:虚拟模板
- 调用
{{模板名|Module:TemplateParameters2}}
- 模板内:
技术限制
由于MediaWiki禁止模板迭代调用,因此在虚拟模板的code中使用其他虚拟模板可能会出现问题,例如
- 输入
{{虚拟模板|code=一次,{{虚拟模板{{!}}code=二次}} }}
- 显示为“一次,检查到模板循环:Template:虚拟模板”
但若避免递回地传入参数则没有问题,如:
- 输入
{{虚拟模板|code=一次,{{虚拟模板|code=二次}} }}
- 显示为“一次,二次”
此显示的效果与普通模板雷同,此处以{{模板1}}做示范:
- 输入
{{模板1}}
- 显示为“Template:模板1”