2023年政策修订增补工作正在进行中,欢迎参与!
Module:Error
跳转到导航
跳转到搜索
本页面之全部或部分原来自中文维基百科的[1],依 CC BY-SA 3.0 授权引入;原贡献者可以在这里看到。 |
本模块用于生成class属性为error的错误提示,可用于{{Error}},用法详见模板说明。
-- 这个模块实现了{{error}}。
local p = {}
local function _error(args)
local message = args.message or args[1] or error('没有指定的-{zh-cn:信息; zh-tw:資訊}-', 2)
message = tostring(message)
local tag = mw.ustring.lower(tostring(args.tag))
-- 弄清楚我们应该使用什么html标签。
if not (tag == 'p' or tag == 'span' or tag == 'div') then
tag = 'strong'
end
-- 生成html。
local root = mw.html.create(tag)
root
:addClass('error')
:wikitext(message)
return tostring(root)
end
function p.error(frame)
local args
if frame == mw.getCurrentFrame() then
-- 我们正在通过#invoke进行调用。 参数传递给模块
-- 从模板页面,所以使用传递到模板的参数。
args = frame.args
else
-- 我们正在从另一个模块或从调试控制台被调用,所以假设
-- 参数直接传入。
args = frame
end
-- 如果消息参数存在但空白,将其更改为零,以便Lua将会
-- 认为它是假的。
if args.message == "" then
args.message = nil
end
return _error(args)
end
return p