Module:ProcessArgs/doc
This is the documentation page for Module:ProcessArgs
该模块将参数添加到一个表中以便模块使用。
用法
该模块通常只能在其他模块中调用,否则会出错。
norm函数
<syntaxhighlight lang="lua"> require('Module:ProcessArgs').norm(origArgs) </syntaxhighlight>
origArgs
:可选(表),用于指定args
表,默认值为父框架[注 1]的args
表。值为其他类型(包括nil
)时取默认值。
该函数会将origArgs
表中所有值的多余空字符删去(若表中某个值全部由空字符组成,则将其设置为nil
),并返回修改后的表。
merge函数
<syntaxhighlight lang="lua"> require('Module:ProcessArgs').merge(origArgs,parentArgs,norm) </syntaxhighlight>
origArgs
:可选(表),用于指定args
表,默认值为当前框架[注 2]的args
表。值为其他类型(包括nil
)时先用该值覆盖norm
的值,然后取默认值。parentArgs
:可选(表),用于指定args
表,当origArgs
不是表时默认值为父框架[注 1]的args
表。值为其他类型(包括nil
)时会出错。norm
:可选(布尔值),用于指定是否将表中全部由空字符组成的值设置为nil
。当origArgs
不是表时取origArgs
的值。
该函数会将origArgs
和parentArgs
这两个表合并(若两个表有相同的键,则优先取parentArgs
中的值),同时将表中所有值的多余空字符删去,并返回合并后的表。
示例
假设模块:Example包含以下代码:
<syntaxhighlight lang="lua"> local p = {} function p.args(f) local arg1 = require('Module:ProcessArgs').norm() local arg2 = require('Module:ProcessArgs').norm(f.args) local arg3 = require('Module:ProcessArgs').merge(true) return mw.allToString(arg1[1],arg2[2],arg2['args'],arg3.name) end return p </syntaxhighlight>
Template:Example包含以下代码:
-{}-{{#invoke:Example|args|foo| bar |ba z|name= na me }}
页面Example包含以下代码:
-{}-{{Example| a rg1 |2=arg2|args=abc }}
那么页面Example将会显示:
a rg1 bar nil na me