模組:Yesno/doc
外觀
此頁面為 Module:Yesno 的說明文件
此模組文件被引用於約3,240,000個頁面,佔全部頁面的41%。 為了避免造成大規模的影響,所有對此模組文件的編輯應先於沙盒或測試樣例上測試。 測試後無誤的版本可以一次性地加入此模組文件中,但是修改前請務必於討論頁發起討論。 模板引用數量會自動更新。 |
此模組文件已被保護。此為高度可見模組文件,其已用於大量條目或被頻繁替換引用。由於破壞或失誤會影響諸多頁面,即便細小的改動也可能導致大量伺服器負載,因此已被保護,不可編輯。 |
本模塊提供用於處理布爾值或形如布爾值的字符串輸入的一致接口。Lua允許布爾值true
和false
,wiki代碼則只能用像yes、no這樣的詞語來表達布爾值。本模塊處理這些字符串並將其轉化為布爾值,以供Lua處理。對於nil
值依舊返回nil
,以允許區分nil
和false
。本模塊同樣接受其他的Lua結構輸入,如布爾值、數字、表、函數。如果傳入的值不能被理解為布爾值或nil
,可以指定一個要返回的默認值。
語法
[編輯]yesno(value, default)
value
是需要測試的值。布爾值輸入或類似於布爾值的輸入(見下方)總是視為true
或false
,nil
總是視為nil
。其他的值一律取default
。
用法
[編輯]首先加載模塊。注意只能由其他Lua模塊加載,而不是一般的wiki頁面。對於一般的wiki頁面可以使用{{yesno}}。
local yesno = require('Module:Yesno')
一些輸入總是返回true
,一些則是返回false
。nil
值總是返回nil
。
-- 这些总是返回true:
yesno('yes')
yesno('y')
yesno('true')
yesno('1')
yesno(1)
yesno(true)
yesno('是')
yesno('开')
yesno('開')
-- 这些总是返回false:
yesno('no')
yesno('n')
yesno('false')
yesno('0')
yesno(0)
yesno(false)
yesno('否')
yesno('关')
yesno('關')
-- nil值总是返回nil:
yesno(nil)
一些值在匹配之前轉化為小寫:
-- 这些总是返回true:
yesno('Yes')
yesno('YES')
yesno('yEs')
yesno('Y')
yesno('tRuE')
-- 这些总是返回false:
yesno('No')
yesno('NO')
yesno('nO')
yesno('N')
yesno('fALsE')
未定義值
[編輯]如果yesno收到一個上面沒有列出的輸入值,你可以指定一個默認值。如果不提供默認值,則這些輸入會返回nil
。
-- 这些会返回nil:
yesno('foo')
yesno({})
yesno(5)
yesno(function() return '这是函数' end)
-- 这些会返回true:
yesno('foo', true)
yesno({}, true)
yesno(5, true)
yesno(function() return '这是函数' end, true)
-- 这些返回字符串"bar":
yesno('foo', 'bar')
yesno({}, 'bar')
yesno(5, 'bar')
yesno(function() return '这是函数' end, 'bar')
注意空白字符串也是如此:
yesno('') -- Returns nil.
yesno('', true) -- Returns true.
yesno('', 'bar') -- Returns "bar".
儘管空字符串在維基文本中的計算結果通常為false,但在Lua中的仍是視為true。該模塊傾向於Lua行為而不是維基文本行為。如果將空白字符串視為false 對您的模塊很重要,則您需要在處理的早期階段刪除空白參數,例如Module:Arguments就會默認移除空白參數。
處理nil
[編輯]根據定義,
yesno(nil) -- Returns nil. yesno('foo') -- Returns nil. yesno(nil, true) -- Returns nil. yesno(nil, false) -- Returns nil. yesno('foo', true) -- Returns true.
要返回僅有true/false
的二元值,使用這樣的代碼:
myvariable = yesno(value) or false -- 若value为nil,则结果为false。
myvariable = yesno(value) or true -- 若value为nil,则结果为true。
myvariable = yesno('foo') or false -- 未知字符串返回nil,结果为false。
myvariable = yesno('foo', true) or false -- 应用默认值(此处为true),结果为true。