模块:Separated entries

求闻百科,共笔求闻

用途

Module:Separated entries用作mw.text.listToText的模板前端,接收任意数量的位置参数,并使用|separator=将其连接起来。|conjunction=可用于为最后一个和倒数第二个项之间定义不同的间隔。开始的位置参数可使用|start=定义。开头的结尾的空白字符会被截去。如要刻意添加开头和结尾的空白字符,请使用 表示空格,或者使用
表示新行。空项不会产生任何错误。

{{#invoke:Separated entries|main|separator=...}}

参见

上述文档内容嵌入自Module:Separated entries/doc编辑 | 历史
编者可以在本模块的沙盒创建 | 镜像和测试样例创建页面进行实验。
请将模块自身所属的分类添加在文档中。本模块的子页面
-- 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