“模板:Loop/doc”的版本间的差异
< 模板:Loop
小 (导入1个版本) |
|||
第1行: | 第1行: | ||
+ | {{FromOther/CN|site=萌娘百科|originURL=https://zh.moegirl.org.cn/{{FULLPAGENAMEE}}|origin={{FULLPAGENAME}}|copyright=cc|lsubtype=by-nc-sa|lver=3.0|contribURL=https://zh.moegirl.org.cn/index.php?title={{FULLPAGENAMEE}}&action=history}} | ||
== 简介 == | == 简介 == | ||
2024年1月3日 (三) 18:57的最新版本
本页面之全部或部分原来自萌娘百科的模板:Loop/doc,依 CC BY-NC-SA 3.0 CN 授权引入;原贡献者可以在这里看到。 |
简介
该模板可以循环执行语句。相较于解析器函数,因为使用Lua模块进行循环,所以没有100次上限的限制。
用法
{{loop | 自增/减变量名 = 初值 | 终值 | 自增/减量 |do= <nowiki> 循环执行的代码... </nowiki>}}
其中,使用自增/减变量的写法为:{{#var:变量名}}
,如:{{#var:time}}
。
默认的自增/减量在初值小于终值为1,在初值大于终值时为-1。
注意:
- 第一层循环的代码需要用
<nowiki>
标签包裹 - 多层循环中内层循环的代码不需要
<nowiki>
标签包裹
由于使用{{loop}}调用时,上下文会被更改为{{loop}},因此被<nowiki>
标签包裹的代码将无法正常接收模板的接收参数(也即被三对大括号包裹的参数,如{{{1}}}
)
如果需要使用传入的模板接收参数,可以改为直接调用模块:Loop,具体方法为:将{{loop|...}}
替换为{{#invoke:loop|loop|...}}
。
示例
示例1
{{#vardefine:count|0}}<!-- -->{{loop|time=1|101|do= <nowiki>{{#vardefine:count| {{#expr: {{#var:count}} + {{#var:time}} }} }}</nowiki> }} 结果:{{#var:count}}
Lua错误 模块:Loop的第98行:必须设置自增/自减的变量名! 结果:0
示例2
{{#vardefine:count|0}}<!-- -->{{loop|time1=1|5|do=<nowiki> {{loop|time2=1|100|do= {{#vardefine:count| {{#expr: {{#var:count}} + {{#var:time1}} * {{#var:time2}} }} }} }} </nowiki>}} 结果:{{#var:count}}
Lua错误 模块:Loop的第98行:必须设置自增/自减的变量名! 结果:0
示例3
当需要使用模板的接收参数时,请直接调用模块:Loop。
{{#invoke:loop|loop|time=1|5 |do=<nowiki> {{#expr:{{#var:time}} + {{{1|0}}} }}{{{split|、}}} </nowiki> }}
1、2、3、4、5、
若以上代码位于某模板中,则:
{{模板名称}}
的结果为:1、2、3、4、5、{{模板名称|2}}
的结果为:3、4、5、6、7、{{模板名称|2|split=@}}
的结果为:3@4@5@6@7@
与解析器函数的替换
本模板的参数与#loop
略有不同,你可以通过一下方法快速替换:
- 将
#loop:
替换为subst:loop/auto|
。 - 点击“保存更改”。
例子
替换过程中进行的更改以粗体标注。
- 若有使用
#loop
的代码如下:- {{#loop:i|5|10|{{#var:i}}<br />}}
- 将
#loop:
替换为loop/auto|
:- {{subst:loop/auto|i|5|10|{{#var:i}}<br />}}
- 点击保存,原内容被替换为
{{#invoke:loop|loop|i=5|14|do=<nowiki>{{#var:i}}<br /></nowiki> }}