模組:Separated entries
外觀
![]() | 此模組使用Lua語言: |
用途
Module:Separated entries用作mw.text.listToText
的模板前端,接收任意數量的位置參數,並使用|separator=
將其連接起來。|conjunction=
可用於為最後一個和倒數第二個項之間定義不同的間隔。開始的位置參數可使用|start=
定義。開頭的結尾的空白字符會被截去。如要刻意添加開頭和結尾的空白字符,請使用 
表示空格,或者使用
表示新行。空項不會產生任何錯誤。
{{#invoke:Separated entries|main|separator=...}}
參見
- {{Enum}}
- {{#invoke:params|function}}
-- This module takes positional parameters as input and concatenates them with
-- an optional separator. The final separator (the "conjunction") can be
-- specified independently, enabling natural-language lists like
-- "foo, bar, baz and qux".
local compressSparseArray = require('Module:TableTools').compressSparseArray
local p = {}
function p._main(args)
local separator = args.separator
-- Decode (convert to Unicode) HTML escape sequences, such as " " for space.
and mw.text.decode(args.separator) or ''
local conjunction = args.conjunction and mw.text.decode(args.conjunction) or separator
-- Discard named parameters.
local values = compressSparseArray(args)
return mw.text.listToText(values, separator, conjunction)
end
local function makeInvokeFunction(separator, conjunction)
return function (frame)
local args = require('Module:Arguments').getArgs(frame)
args.separator = separator or args.separator
args.conjunction = conjunction or args.conjunction
return p._main(args)
end
end
p.main = makeInvokeFunction()
p.br = makeInvokeFunction('<br />')
p.comma = makeInvokeFunction(mw.message.new('comma-separator'):plain())
return p