Modul:Category handler/doc
Ini ialah laman pendokumenan untuk Modul:Category handler
Templat ini digunakan dalam 5,600,000+ laman. Untuk mengelakkan gangguan yang besar dan beban pelayan yang tidak diperlukan, perubahan kepada templat ini seharusnya hendaklah diuji di sublaman /kotak pasir atau /ujian templat ini, ataupun dalam atau di dalam sublaman pengguna. Perubahan yang sudah dicuba bolehlah ditambahkan dengan satu suntingan ke dalam templat ini. Sila bincangkan perubahan-perubahan tersebut terlebih dahulu pada laman perbincangan sebelum melaksanakannya. |
Modul ini melaksanakan templat {{category handler}}. Templat kategori pengendali membantu templat lain untuk mengautomasikan kedua-dua kategori dan Kategori penyekatan. Untuk maklumat lanjut mengenai menggunakan templat kategori pengendali dalam templat lain, sila lihat template documentation. Teruskan membaca untuk maklumat mengenai menggunakan modul kategori pengendali dalam modul Lua lain, atau untuk maklumat mengenai mengeksport modul ini untuk wiki-wiki lain.
Gunakan dari modul Lua lain
[sunting sumber]Apabila tidak menggunakan modul ini
[sunting sumber]Bagi kes-kes di mana modul yang hanya perlu untuk mengkategorikan di salah satu ruang nama utama (artikel), fail (imej) atau kategori, maka dengan modul ini adalah pembunuhan besar-besaran. Sebaliknya, anda hanya boleh mendapatkan objek tajuk menggunakan mw.title.getCurrentTitle dan periksa lapangan nsText
. Sebagai contoh:
local title = mw.title.getCurrentTitle()
if title.nsText == 'File' then
-- do something
end
Walau bagaimanapun, jika anda memerlukan modul untuk mengkategorikan dalam mana-mana ruang nama lain, maka kami cadangkan anda menggunakan modul ini, kerana ia menyediakan penindasan kategori yang betul dan membuat ia mudah untuk memilih bagaimana untuk mengkategorikan dalam ruang nama yang berbeza.
Ruang nama
[sunting sumber]Modul ini mengesan dan kumpulan semua berbeza Ruang nama digunakan di Wikipedia kepada beberapa jenis. Jenis ini digunakan sebagai nama parameter dalam modul ini.
- main = Ruang/Rencana utama, seperti dalam artikel-artikel Wikipedia biasa.
- talk = Any talk space, such as page names that start with "Talk:", "User talk:", "File talk:" and so on.
- user, wikipedia, file ... = The other namespaces except the talk pages. Namespace aliases are also accepted. See the table below for the full list.
- other = Any namespaces that were not specified as a parameter to the template. See examples below.
- Senarai parameter ruang nama mungkin
(tidak termasuk talk
dan other
)
Namespace | Aliases |
---|---|
main
|
|
pengguna
|
user
|
wikipedia
|
project , wp
|
fail
|
file , imej , image
|
mediawiki
|
|
templat
|
template
|
bantuan
|
help
|
kategori
|
category
|
portal
|
|
mos
|
|
timedtext
|
|
modul
|
module
|
Penggunaan asas
[sunting sumber]Modul ini mengambil masa dua atau lebih parameter. Ini adalah contoh menggunakan program dunia hello:
p = {}
local categoryHandler = require( 'Module:Category handler' ).main
function p.main( frame )
local result = 'Hello world!'
local category = categoryHandler{
'[[Category:Somecat]]',
nocat = frame.args.nocat -- So "nocat=true/false" works
}
category = category or '' -- Check that we don't have a nil value for the category variable.
return result .. category
end
return p
Contoh di atas menggunakan tetapan lalai bagi modul kategori pengendali. Ini bermakna modul contoh yang akan mengkategorikan di muka surat dalam ruang nama berikut:
- main, file, help, category, portal and book
But it will not categorize in any other namespaces, e.g.:
- talk, user, wikipedia, mediawiki, template ...
Dan ia akan tidak mengkategorikan di muka surat disenaraihitamkan. (Lihat seksyen blacklist di bawah.)
Sebab modul kategori pengendali tidak mengkategorikan di beberapa ruang nama adalah bahawa orang-orang dalam ruang nama yang paling modul dan templat hanya menunjukkan atau disenaraikan, tidak digunakan. Oleh itu yang paling modul dan templat tidak mengkategorikan mereka dalam ruang nama.
Mana-mana modul atau templat yang dimaksudkan untuk satu atau lebih dari ruang nama mana modul ini mengkategorikan boleh menggunakan sintaks asas seperti di atas.
Penggunaan Lanjutan
[sunting sumber]Modul ini mengambil masa satu atau lebih parameter dinamakan selepas jenis halaman yang berbeza seperti yang disenaraikan dalam seksyen namespaces di atas. Dengan menggunakan parameter anda boleh menentukan dengan tepat di mana ruang nama templat anda harus mengkategorikan. Seperti ini:
p = {}
local categoryHandler = require( 'Module:Category handler' ).main
function p.main( frame )
local result = 'This is a module meant for articles and talk pages.'
local category = categoryHandler{
main = '[[Category:Somecat1]]', -- Categorize in main (article) space
talk = '[[Category:Somecat2]]', -- Categorize in talk space
nocat = frame.args.nocat -- So "nocat=true/false" works
}
category = category or '' -- Check that we don't have a nil value for the category variable.
return result .. category
end
return p
Modul atas hanya akan mengkategorikan di ruang utama dan bercakap. Tetapi ia tidak akan mengkategorikan di muka surat / arkib kerana mereka disenaraihitamkan. (Lihat seksyen blacklist di bawah.) Dan jika anda perlu menunjukkan (berbincang) modul pada talkpage, maka anda boleh memberi makan "nocat='true'
" untuk mengelakkan dari templat yang mengkategorikan. (Lihat seksyen nocat below.) Like this:
== My new module == Hey guys, have you seen my new module? {{#invoke:mymodule|main|nocat=true}} Nice, isn't it? --~~~~
Kadang-kadang kita mahu menggunakan kategori yang sama dalam beberapa ruang nama, kemudian melakukan seperti ini:
p = {}
local categoryHandler = require( 'Module:Category handler' ).main
function p.main( frame )
local result = 'This is a module used in several namespaces.'
local category = categoryHandler{
main = '[[Category:Somecat1]]',
[ 1 ] = '[[Category:Somecat2]]', -- For help and user space
help = 1,
user = 1,
talk = '', -- No categories on talk pages
other = '[[Category:Somecat3]]', -- For all other namespaces
nocat = frame.args.nocat -- So "nocat=true/false" works
}
category = category or '' -- Check that we don't have a nil value for the category variable.
return result .. category
end
return p
Dalam contoh di atas kita menggunakan parameter yang bernombor untuk memberi makan salah satu kategori, dan kemudian kita memberitahu modul ini menggunakan parameter yang bernombor untuk kedua-dua bantuan dan ruang pengguna.
Modul kategori pengendali memahami nombor yang tidak terhad parameter bernombor.
lain-lain parameter mentakrifkan apa yang perlu digunakan dalam ruang nama baki yang belum jelas menjadi data diberi makan.
Nota yang kosong tetapi ditakrifkan cakap parameter. Bahawa berhenti modul ini dari menunjukkan apa yang telah diberi makan kepada lain-lain parameter, apabila di ruang cakap.
Modul kategori pengendali juga mempunyai parameter yang dipanggil semua. Ia berfungsi seperti ini:
p = {}
local categoryHandler = require( 'Module:Category handler' ).main
function p.main( frame )
local result = 'This is a module used in all namespaces.'
local category = categoryHandler{
all = '[[Category:Somecat1]]', -- Categorize in all namespaces
nocat = frame.args.nocat -- So "nocat=true/false" works
}
category = category or '' -- Check that we don't have a nil value for the category variable.
return result .. category
end
return p
Contoh di atas akan mengkategorikan dalam semua ruang nama, melainkan bukan pada halaman disenaraihitamkan. Jika anda mahu untuk menunjukkan bahawa modul pada laman, kemudian gunakan "nocat=true
" untuk mengelakkan templat dari mengkategorikan.
Kami mencadangkan mengelakkan semua parameter, sejak modul dan templat harus sebaik-baiknya hanya mengkategorikan dalam ruang nama mereka perlu.
Parameter semua juga boleh digabungkan dengan seluruh parameter. Seperti ini:
p = {}
local categoryHandler = require( 'Module:Category handler' ).main
function p.main( frame )
local result = 'This is a module used in all namespaces.'
local category = categoryHandler{
all = '[[Category:Somecat1]]', -- Categorize in all namespaces
main = '[[Category:Somecat2]]', -- And add this in main space
other = '[[Category:Somecat3]]', -- And add this in all other namespaces
nocat = frame.args.nocat -- So "nocat=true/false" works
}
category = category or '' -- Check that we don't have a nil value for the category variable.
return result .. category
end
return p
Jika modul di atas diletakkan pada artikel, maka ia akan menambah kategori "Somecat1" dan "Somecat2". Tetapi pada semua jenis lain halaman ia sebaliknya akan menambah "Somecat1" dan "Somecat3". Sebagai contoh yang menunjukkan, yang semua parameter bekerja secara bebas daripada yang lain daripada parameter.
Halaman kecil
[sunting sumber]Modul kategori pengendali memahami halaman kecil parameter. Seperti ini:
p = {}
local categoryHandler = require( 'Module:Category handler' ).main
function p.main( frame )
local result = 'This is a module used in all namespaces.'
local category = categoryHandler{
subpage = 'no' -- Don't categorize on subpages
wikipedia = '[[Category:Somecat]]',
nocat = frame.args.nocat -- So "nocat=true/false" works
}
category = category or '' -- Check that we don't have a nil value for the category variable.
return result .. category
end
return p
Jika "subpage='no'
" kemudian templat ini tidak akan mengkategorikan pada halaman kecil. Untuk majlis itu jarang berlaku hanya andaingin mengkategorikan pada halaman kecil, kemudian gunakan "subpage='only'
". Jika halaman kecil kosong atau undefined kemudian templat ini mengkategorikan kedua-dua pada petak halaman dan pada halaman kecil.
Senarai Hitam
[sunting sumber]Modul ini mempunyai senarai hitam di laman-laman dan jenis halaman di mana templat tidak perlu auto-Kategorikan. Oleh itu modul yang menggunakan meta-templat ini kehendak misalnya tidak mengkategorikan di muka surat / arkib dan pada halaman kecil daripada Wikipedia:Template messages.
Jika anda mahu templat untuk mengkategorikan pada halaman yang disenarai hitam, kemudiannya menyuapkan "nocat = false
" untuk modul apabila anda meletakkannya pada halaman, dengan itu melangkau semak senarai hitam. Ambil perhatian bahawa modul ini hanya mengkategorikan jika ia mempunyai data untuk ruang nama itu. Sebagai contoh, jika sintaks asas digunakan (lihat basic usage di atas), maka walaupun anda menetapkan "nocat = false
" templat tidak akan mengkategorikan pada halaman perbualan, kerana ia tidak mempunyai data untuk laman perbincangan. Tetapi ia mempunyai data untuk ruang bantuan, jadi pada laman bantuan disenaraihitamkan ia akan mengkategorikan.
Senarai hitam yang terletak di kotak meja konfigurasi cfg.blacklist
near the top of the module code.
The "nocat" parameter
[sunting sumber]This module understands the nocat parameter:
- If "
nocat = true
" then this template does not categorize. - If nocat is
nil
then this template categorizes as usual. - If "
nocat = false
" this template categorizes even when on blacklisted pages. (See section blacklist above.) - The nocat parameter also accepts aliases for
true
andfalse
as defined by Module:Yesno, e.g. "yes", "y", "true", and 1 fortrue
, and "no", "n", "false", and 0 forfalse
.
Modul dan templat yang menggunakan {{category handler}} hendaklah mengemukakan nocat, supaya mereka juga memahami nocat. kod ini "nocat = frame.args.nocat
" ditunjukkan dalam contoh-contoh di muka surat ini melakukan hal tersebut.
Kategori "parameter"
[sunting sumber]Untuk keserasian ke belakang modul ini juga memahami kategori parameter. Ia berfungsi sama seperti nocat. Seperti ini:
- Jika "
categories = false
" kemudian templat ini telah tidak mengkategorikan. - Jika kategori kosong atau tak ditentukan kemudian templat ini mengkategorikan seperti biasa.
- Jika "
categories = true
" templat ini mengkategorikan walaupun di muka surat disenaraihitamkan. - Parameter kategori juga menerima alias untuk
true
andfalse
sebagaimana yang ditakrifkan oleh Module:Yesno, e.g. "yes", "y", "true", dan 1 daritrue
, and "no", "n", "false", dan 0 darifalse
.
Kategori2 "parameter"
[sunting sumber]Untuk keserasian ke belakang templat ini jenis menyokong lama "kategori =" parameter. Tetapi nama parameter "kategori" telah digunakan dalam modul ini untuk memberi makan untuk kategori data apabila di ruang kategori. Jadi, ini menggunakan templat kategori2 untuk kegunaan yang sama dengan nocat. Seperti ini:
- Jika "
category2 =
" (kosong tetapi ditakrifkan), atau "category2 = 'no'
", atau jika kategori2 diberi makan apa-apa data yang lain (kecuali seperti yang dinyatakan di dalam kedua-dua mata yang akan datang), maka templat ini telah tidak mengkategorikan. - Jika category2 adalah tak ditentukan atau jika "
category2 = '¬'
", kemudian templat ini mengkategorikan seperti biasa. - Jika "
category2 = 'yes'
" templat ini mengkategorikan walaupun di muka surat disenaraihitamkan.
Kategori dan teks
[sunting sumber]Selain daripada kategori, anda boleh makan apa-apa lagi untuk modul ini, misalnya beberapa teks. Seperti ini:
p = {}
local categoryHandler = require( 'Module:Category handler' ).main
function p.main( frame )
local result = 'This is a module used on talk pages.'
local category = categoryHandler{
talk = '[[Category:Somecat]]',
other = '<p class="error">This module should only be used on talk pages.</p>',
nocat = frame.args.nocat -- So "nocat=true/false" works
}
category = category or '' -- Check that we don't have a nil value for the category variable.
return result .. category
end
return p
Apabila kod modul di atas digunakan pada apa-apa selain daripada halaman perbualan, ia akan kelihatan seperti ini:
- This is a module used on talk pages.
This module should only be used on talk pages.
Teks yang tidak akan menunjukkan pada muka surat yang disenarai hitam, jadi tidak menggunakan kaedah ini untuk menunjukkan apa-apa maklumat penting. Pemakanan "nocat = 'true'
" kepada templat yang menyembunyikan teks, sebagaimana ia menyembunyikan apa-apa kategori.
"halaman" parameter
[sunting sumber]Bagi tujuan ujian dan demonstrasi modul ini boleh mengambil parameter bernama halaman. Seperti ini:
p = {}
local categoryHandler = require( 'Module:Category handler' ).main
function p.main( frame )
local category = categoryHandler{
main = 'Category:Some cat',
talk = 'Category:Talk cat',
nocat = frame.args.nocat, -- So "nocat=true/false" works
page = 'User talk:Example'
}
return category
end
return p
Dalam kod di atas kita dengan sengaja meninggalkan daripada kurungan di seluruh nama-nama kategori supaya kita melihat output pada halaman. Tidak kira pada jenis halaman kod di atas digunakan ia akan kembali ini:
- Category:Talk cat
halaman parameter membuat berkelakuan modul ini betul-betul seolah-olah pada laman tersebut. Walaupun senarai hitam yang bekerja. Nama halaman yang tidak perlu menjadi halaman yang telah ada.
Jika halaman parameter kosong atau tak ditentukan, nama halaman semasa menentukan hasilnya.
Anda boleh membuatnya begitu modul anda juga memahami halaman parameter. Ini bermakna anda boleh menguji bagaimana templat anda akan mengkategorikan di muka surat yang berbeza, tanpa mempunyai untuk benar-benar mengedit halaman tersebut. Kemudian lakukan seperti ini:
p = {}
local categoryHandler = require( 'Module:Category handler' ).main
function p.main( frame )
local category = categoryHandler{
main = 'Category:Some cat',
talk = 'Category:Talk cat',
nocat = frame.args.nocat, -- So "nocat=true/false" works
page = frame.args.page -- For testing
}
return category
end
return p
Parameter
[sunting sumber]Senarai semua parameter:
- First positional parameter - for default settings
- subpage = 'no' / 'only'
- 1, 2, 3 ...
- all = '[[Category:Somecat]]' / 'Text'
- main = 1, 2, 3 ... / '[[Category:Somecat]]' / 'Text'
- ...
- other = 1, 2, 3 ... / '[[Category:Somecat]]' / 'Text'
- nocat = frame.args.nocat / true / false / 'yes' / 'no' / 'y' / 'n' / 'true' / 'false' / 1 / 0
- categories = frame.args.categories / false / true / 'no' / 'yes' / 'n' / 'y' / 'false' / 'true' / 0 / 1
- category2 = frame.args.category or '¬' / / 'no' / not defined / '¬' / 'yes'
- page = frame.args.page / 'User:Example'
Perhatikan bahawa nilai kosong kepada parameter "utama" ... "lain-lain" mempunyai makna khas (lihat contoh di atas). Parameter "semua" tidak memahami parameter bernombor, kerana tidak sekali keperluan untuk itu.
Mengeksport ke wiki-wiki lain
[sunting sumber]Modul ini boleh dieksport ke wiki-wiki lain dengan menukar nilai-nilai dalam konfigurasi kotak meja cfg
. Semua nilai-nilai pembolehubah adalah dikonfigurasikan, jadi selepas nilai konfigurasi telah ditetapkan tidak ada keperluan untuk mengubah kod modul utama. Butiran setiap nilai konfigurasi dimasukkan dalam komen kod modul. Di samping itu, modul ini memerlukan Module:Namespace detect boleh didapati di wiki tempatan.
Lihat juga
[sunting sumber]- {{Category handler}} – untuk menggunakan modul ini dengan templat, daripada modul Lua.
- Wikipedia:Kategori penyekatan – Bagaimana-untuk panduan.
- Wikipedia:WikiProjek Kategori Sekatan – WikiProjek.
- Wikipedia:Ruang nama – Menyenaraikan semua ruang nama.