یک الگو در واقع یک صفحهٔ ویکیپدیا است که برای گنجاندهشدن در صفحههای دیگر ایجاد شدهاست.
این صفحه یک راهنمای چگونه انجام دادن است. که یک کار یا فرایند را در ویکیپدیای فارسی شرح میدهد. این صفحه یکی از سیاستها یا رهنمودهای ویکیپدیا نیست، زیرا هنوز توسط اجتماع مورد بررسی و تأیید قرار نگرفته است. |
ویکیمتن |
---|
الگوها معمولاً دربردارندهٔ محتوایی تکراری هستند که احتمالاً لازم است در تعدادی از صفحهها یا مقالهها نمایش یابند. از الگوها معمولاً برای پیامهای تکرارشونده، هشدارها و اعلانهای استاندارد، جعبههای اطلاعات، جعبههای ناوبری و مقاصد مشابه دیگر استفاده میشود.
معمولترین روش برای گنجاندن یک الگو در صفحهها، تراگنجانش نام دارد. در این روش، ویکیمتن صفحهٔ مقصد با استفاده از عبارت نحوی {{نام الگو}}
شامل ارجاعی به الگو میشود. روش دیگر استفاده از الگوها در صفحههای دیگر، جانشانی است که در آن، محتوای الگو تنها یکبار و فقط در زمان ذخیرهٔ صفحه، به درون ویکیمتن صفحهٔ مقصد کپی میشود.
صفحهٔ راهنما:آموزش سریع الگوها بهطور مختصر به معرفی این موضوع میپردازد. صفحههای راهنمای بیشتر در مدیاویکی و ویکیمدیا را میتوانید در صفحههای راهنمای الگو در مدیاویکی، راهنمای الگو در فراویکی و راهنمای پیشرفتهٔ الگوها در فراویکی مطالعه کنید.
برای پیوند دادن به یک الگو در متن صفحه به شکلی که آکولادهای دربرگیرندهٔ آن نیز نمایش یابند، میتوانید از الگوی الگو استفاده کنید. انگیزهٔ اصلی از انجام این کار، ارائهٔ راهنمای استفاده و درج در توضیحات الگو است. در زیر، نمونهای کوتاه از این نحوهٔ استفاده آمدهاست:
{{الگو|فلان}}
اکثر الگوها صفحههایی در فضای نام الگو هستند. به این معنی که از عنوانی بهشکل «الگو:فلان» برخوردار هستند. با این حال، تراگنجانش و جانشانی صفحهها از تقریباً هر فضای نام دیگری نیز ممکن است. بنابراین، برخی صفحههای الگو در فضاهای نام دیگر مانند فضای نام کاربر قرار دارند. الگوها دارای یک صفحهٔ بحث وابسته نیز هستند.
الگوها میتوانند شامل هر گونهٔ دلخواهی از ویکیمتن، از جمله فراخوانی الگوهای دیگر باشند. ظرفیتهای برنامهنویسی در الگو در بعضی زمینهها دارای محدودیت است؛ از جمله، برای این موارد ظرفیتی محدود وجود دارد: مقادیر قابل تنظیم (که به آنها پارامتر گفته میشود)؛ دستورهای محاسبه و انشعاب با استفاده از توابع تجزیهگر؛ و دسترسی به متغیرهای خاص ویکی (موسوم به کلمات جادویی) مانند تاریخ، زمان و نام صفحهها. الگوها همچنین میتوانند از برچسبهای اچتیامال برای مشخص کردن بخشهایی از ویکیمتن استفاده کنند تا این بخشها در زمان تراگنجانش یا جانشانی الگو مشخص شوند. مجموع این موارد باعث میشود که گاهی ظاهر صفحهٔ خود الگو با محتوایی که پس از تراگنجانش آن به دست میآید، یکسان نباشد (برای مثال، صفحهٔ الگو میتواند شامل توضیحات الگو، ردهها و مواردی دیگر تنها برای خود الگو باشد که در صفحههای محلِ کاربرد الگو، دیده نخواهند شد).
نحوهٔ استفاده از الگوها: برای تراگنجانش یک الگو در یک مقاله یا صفحهٔ دیگر، عبارت {{نام الگو}}
را در ویکیمتن صفحه و در جای مورد نظر برای نمایش الگو تایپ کنید. در صورتی که عنوان الگو با حروف انگلیسی است، فرقی نمیکند که حرف اول عنوان آن را با حروف بزرگ بنویسید یا حروف کوچک.
پیشوند الگو:
که پیش از نام الگو قرار دارد، پیشوندی پیشفرض است و لازم نیست در زمان تراگنجانش درج شود. با این حال، در زمان استفاده از الگوهای قرارگرفته در فضاهای نام دیگر، پیشوندهایی نظیر کاربر:
باید در زمان استفاده از الگو درج شوند (مثلاً {{کاربر:فلانی/جعبه کاربر}}
. برای تراگنجانش صفحهای که در فضای نام اصلی قرار دارد، پیش از عنوان صفحه یک علامت دونقطه «:» قرار دهید (مثال: {{:نام صفحه}}
).
یادداشت: اقدام به تراگنجانش الگویی که وجود ندارد، درست مشابه پیونددهی به هر صفحهٔ ناموجود دیگر، منجر به تولید یک پیوند قرمز میشود. دنبالکردن این پیوند قرمز، امکان ایجاد آن الگوی خاص را فراهم میکند. تراگنجانش صفحهها میان پروژههای مختلف امکانپذیر نیست (مثلاً میان نسخههای زبانی مختلف ویکیپدیا یا از ویکیپدیا به ویکیکتاب)، برای استفاده از یک الگو در یک پروژهٔ زبانی دیگر، یک نسخه از همان الگو باید در آن پروژه نیز ایجاد شود.
نحو ابتدایی برای تراگنجانش الگوها که در بالا به آن اشاره شد، میتواند با افزودهشده پارامترها گسترش یابد. این پارامترها برای کنترلکردن خروجی الگو کاربرد دارند. نحو الگوها با استفاده از پارامترها بهصورت زیر است: {{نام الگو|پارامتر|پارامتر|...}}
. مثلاً اگر الگویی به اسم «جمع» داشته باشیم که پارامترهایی عددی بگیرد و مجموع آنها را برگرداند، کاربرد چنین الگویی میتواند به این شکل باشد: {{جمع|۱۲|۸|۴۹}}
و خروجی الگو هم فرضاً ۶۹ خواهد بود.
در نحو الگوها، پارامتر
میتواند تنها شامل یک مقدار باشد (که به این نوع پارامترها پارامترهای نامگذارینشده میگویند) یا شامل نام و مقدار پارامتر باشد، بهشکل نام=مقدار
که به آن پارامترها نامگذاریشده میگویند. در واقع، پارامترهای نامگذارینشده به صورت خودکار نامگذاری میشوند و نامشان با اعداد لاتین 1
، 2
، 3
و الی آخر نیز مورد استفاده است. به بیان دیگر، دستور الگویی که بالاتر نوشته شده، در اصل از دید نرمافزار معادل {{جمع|1=۱۲|2=۸|3=۴۹}}
است.
توجه کنید که الگوها میتوانند از ترکیبی از پارامترهای نامگذاریشده و پارامترهای نامگذارینشده استفاده کنند. در دستوری شبیه به {{الگو|نام=فلان|سن=بهمان|بسیار}}
، دو پارامتر نامگذاریشده به کار رفتهاند و یک پارامتر نامگذارینشده. پارامترهای نامگذارینشده به ترتیب شماره میخورند و در این شمارهگذاری، پارامترهای نامگذاریشده نادیده گرفته میشوند. در مثال بالا، بیسار
مقدار پارامتر 1
خواهد بود، نه مقدار پارامتر 3
، چون اولین پارامتر نامگذارینشدهای است که فراخوانی شدهاست.
نویسههای فاصله خالی (فاصلهها، جهشها، سرخط) از ابتدا و انتهای نام و مقادیر پارامترهای نامگذاریشده جدا میشوند، اما این اتفاق در میانهٔ عبارت رخ نمیدهد: بنابراین {{... | پارامتر = این یک آزمایش است}}
دارای تأثیری یکسان با {{... |پارامتر=این یک آزمایش است}}
خواهد بود. این قاعده به پارامترهای نامگذارینشده، که در آنها تمامی نویسههای فاصله خالی محفوظ هستند، اعمال نمیشود.
آن که چه پارامترهایی (در صورت وجود) میتوانند یا باید به یک الگو داده شوند و چگونگی نامگذاری آنها، بستگی به نحوهٔ کدنویسی آن الگو دارد. پارامترهای نامگذاریشده را به هر ترتیبی میتوان تعریف کرد. از پارامترهای زائد یا پارامترهایی با نامگذاری بد چشمپوشی خواهد شد؛ پارامترهای تعریفنشده با مقادیر پیشفرض پر میشوند. یک یک پارامتر بیش از یکبار تعریف شدهباشد، آخرین مقدار وارد شده برای آن در نظر گرفته خواهد شد.
مقدار یک پارامتر میتواند یک میتواند یک رشتهٔ خالی باشد؛ به این معنا که بلافاصله پس از نویسهٔ خط عمودی یا علامت مساوی، خط عمودی بعدی یا آکولادهای پایانی الگو قرار گیرند. این، با چشمپوشی کلی از یک پارامتر، که درواقع بهعنوان پارامتر تعریفنشده در نظر گرفته میشود، متفاوت است؛ با این حال، الگوها معمولاً به گونهای نوشته میشوند که در هر دو حالت رفتاری یکسان از خود نشان دهند.
حتی در صورتی که پارامترها در کد الگو تعریف نشدهباشند، میتوان آنها را در زمان استفاده از الگو بهکار برد (هرچند که نتیجهای نخواهند داد). برای مثال، در ویکینبشته پارامتر |reason=
غالباً بهعنوان یک شبهپارامتر و بهمنظور ارائهٔ یک توضیح مختصر برای دلیل بهکارگیری الگو استفاده میشود. برخی الگوها، پودمان بررسی پارامترهای نامعلوم را فراخوانی میکنند تا به ویرایشگر هشدار دهند که یکی از پارامترهایی که در حال استفاده از آن است، در کدهای الگو تعریف نشدهاست؛ این قابلیت بیشتر در جعبههای اطلاعات و سایر الگوهایی که تعداد زیادی پارامترهای پیچیده دارند، کاربرد دارد که در آنها وجود یک پارامتر ناشناخته معمولاً حاصل خطای غیرعمدی است. در صورتی که چنین الگویی را برای افزودن یک پارامتر جدید بهروزرسانی کردید، فراخوانی پودمان در الگو نیز برای دربرگرفتن پارامتر جدید باید بهروز شود.
استفاده از یک الگو دارای شباهت زیادی به فراخوانی یک تابع در زبانهای برنامهنویسی است، چرا که فراخواندن آن، مقداری (خروجی) را برمیگرداند. همچنین بعضی الگوها، مشابه توابع، پارامترهایی که باعث تغییر خروجی میشوند را میپذیرند.
ویکیپدیا با استفاده از نرمافزار مدیاویکی درست شدهاست. در مدیاویکی متغیرها دارای معنایی اختصاصیتر هستند که آنها را از الگوها متمایز میسازد، اما هردوی آنها با آکولادهای دوقلو {{}}
شناسایی میشوند و هردوی آنها قادر به برگرداندن مقدار هستند.
نام همهٔ متغیرهای مدیاویکی در اصلی به انگلیسی است و تماماً با حروف بزرگ نوشته میشود (مثل متغیر {{PAGENAME}}
که نام صفحه را بر میگرداند). با این حال برای نام متغیرها، معادل فارسی نیز ساخته شدهاست؛ مثلاً {{نامصفحه}}
مترادف {{PAGENAME}}
است. در مقایسه، نام الگوها از همان ویژگیهای ابتدایی و محدودیتهایی برخوردار است که به نام صفحهها نیز اعمال میشود: این نامها به بزرگی و کوچکی حروف حساس هستند (بهجز نویسهٔ اول نام)؛ زیرخطها، همانند فاصلهها تجزیه میشوند؛ و نام الگوها نمیتواند شامل این نویسهها باشد: # < > [ ] | { }
. دلیل این محدودیت این است که این نویسهها از پیش برای نشانهگذاری ویکی و اچتیامال کنار گذاشته شدهاند.
علامت مربع #
با عنوان یک شناسهٔ قطعه شناخته میشود؛ چرا که برای مشخصکردن یک قطعه یا یک بخش از یک سند (مانند بخشی در یک مقالهٔ ویکیپدیا) بهکار میرود. اگرچه از این نویسه برای پیوند دادن به یک بخش از صفحهٔ الگو میتوان استفاده کرد (مانند الگو:درگاه#مثال)، اما دلیلی برای قرار دادن یک شناسهٔ قطعه یا نام یک قطعه در ارجاع به الگو وجود ندارد. بهعنوان مثال، در عبارت {{درگاه#مکان|کتاب}}
، رشتهٔ #مکان
کاربردی ندارد و در نتیجه از آن صرف نظر خواهد شد.
هنگامی که یک الگو جانشانی شود، محتوای آن بهجای تراگنجانش، در صفحه سختنویسی میشوند. برای آگاهی از چگونگی و زمان مناسب برای جانشانی یک الگو، راهنما:جانشانی را ببینید.
یادداشت: اگر قصد دارید هر یک از این نمونهها را آزمایش کنید، لطفاً از صفحهٔ تمرین الگو یا یکی از زیرصفحههای کاربری خودتان مانند صفحهٔ تمرینتان استفاده کنید.
الگو:لامبدا یک نمونهٔ بسیار ساده از الگوها است که برای قرار دادن نماد لامبدا (λ) در محل فراخوانی خود در متن صفحه بهکار میرود. در میان برنامهنویسان، اینطور گفته میشود که الگو، نماد لامبدا (λ) را برمیگرداند.
روی الگو:لامبدا کلیک کرده و در صفحهٔ الگو روی زبانهٔ «ویرایش متنی» در بالای صفحه کلیک کنید تا کد الگو (ویکیمتن آن) را مشاهده کنید. بخش «فعال» کد که با عنوان بسط الگو شناخته میشود، عبارت λ
است. باقی ویکیمتن الگو نیز با برچسبهای <noinclude>
محصور شدهاست تا در صفحهٔ خود الگو نمایش یابد، اما در زمان استفاده (یا فراخوانی) الگو در صفحهای دیگر، نمایش داده نشود.
برای تراگنجانش الگو:لامبدا در یک صفحهٔ دیگر (یعنی استفاده از الگو در صفحهٔ دیگر)، عبارت {{لامبدا}}
را در ویکیمتن صفحهٔ مقصد تایپ کرده و دکمهٔ پیشنمایش را فشار دهید. پس از آن، پیشنمایشی از صفحه نمایش خواهد یافت که در آن فراخوانی الگو با بسط آن جایگزین شدهاست؛ بهگونهای که گویی متن صفحه دربردارندهٔ λ
در محل قرارگیری الگو باشد. صفحهٔ نمایشیافته متعاقباً شامل متن «λ» خواهد بود. برای الگوها میتوان تغییرمسیر هم ایجاد کرد. مثلاً الگو:Lambda تغییرمسیری به الگو:لامبدا است در نتیجه استفاده از دستور {{lambda}}
یا {{Lambda}}
نیز نتیجهای مشابه استفاده از دستور {{لامبدا}}
ایجاد میکند. توجه کنید که بزرگی و کوچکی حرف اول نام الگو تفاوتی ایجاد نمیکند.
برای تمرین، عبارت یازدهمین حرف از الفبای یونانی لامبدا ({{لامبدا}}) است
را تایپ کنید تا در زمان پیشنمایش صفحه، یا پس از ذخیرهکردن تغییرات، عبارت «یازدهمین حرف از الفبای یونانی لامبدا (𝜆) است» را مشاهده کنید. شما میتوانید بدون اطلاع از جزئیات کد الگوها از آنها استفاده کنید؛ تنها لازم است که آنچه الگو تولید میکند و معمولاً در صفحهٔ خود الگو توضیح داده شدهاست را بهیاد داشته باشید.
راهی دیگر برای استفاده از این الگو، جانشانی کردن آن است. اگر عبارت یازدهمین حرف از الفبای یونانی لامبدا ({{جا:لامبدا}}) است
را تایپ کنید و پیشنمایش را بفشارید یا صفحه را ذخیره کنید، باز هم جملهٔ «یازدهمین حرف از الفبای یونانی لامبدا (λ) است» را مشاهده خواهید کرد. اما اگر پس از ذخیره کردن صفحه، دوباره به ویکیمتن ذخیرهشده بنگرید، خواهید دید که وقتی صفحه را ذخیره کردید، فراخوانیهای الگو بهواقع با بسط الگو جایگزین شدهاند. جانشانی الگو باعث میشود که پیوند میان متن خروجی و صفحهٔ الگو شکسته شود؛ در نتیجه اگر در آینده دستور الگو تغییر یابد، آن تغییرات در صفحههایی که پیشتر الگو در آنها جانشانی شده منعکس نخواهند شد.
الگوی {{درباره}}
نمونهای است از یک الگو که پارامتر نیز میپذیرد. نوشتن عبارت {{درباره|چگونگی استفاده از الگوها|شیوهٔ استفاده از پودمانها|راهنما:پودمان}}
در صفحهٔ تمرین را امتحان کنید نتیجهٔ آن، متن زیر خواهد بود:
در مثال بالا، الگوی {{درباره}}
از سه پارامتر نامگذارینشده استفاده میکند، اما همین الگو را میتوان با تعداد مختلفی از پارامترها نیز استفاده کرد که نتیجهٔ آن، مطابق با آنچه در مستندات این الگو آمده، اندکی متفاوت خواهد بود. بهعنوان نمونه: {{درباره||شیوهٔ استفاده از پودمانها|راهنما:پودمان}}
. به کاربرد یک پارامتر خالی در این نمونه دقت کنید. نویسههای |
که خط عمودی نامیده میشوند، اسم الگو را از پارامترهایش و پارامترها را از همدیگر جدا میکنند. جایی که دو خط عمودی متوالی میبینید به این معنی است که نخستین پارامتری که به الگو «فرستاده شده» یک رشتهٔ خالی است؛ خالی بودن پارامتر اول در این الگو منجر به چشمپوشی از جملهٔ «درباره» در ابتدای خروجی الگو خواهد شد. فراخوانی الگو به این شکل، این عبارت را تولید خواهد کرد:
سایر الگوها، بهویژه آنهایی که پیچیدهتر هستند، پارامترهای نامگذاریشده یا ترکیبی از پارامترهای نامگذاریشده و نامگذارینشده را میپذیرند. الگو:ماتریس بازده نمونهای ساده از این گونه از الگوها است که برای ایجاد یک جدول دو در دو بهکار میرود. برای مثال:
نشانهگذاری | نمایش | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
{{ماتریس بازده| بالاراست = ۷ | بالاچپ = ۵ | پایینراست = ۹ | پایینچپ = ۲ | نام = استفادهٔ آموزشی}} |
| ||||||||||||
برای آگاهی از قابلیتهای بیشتر الگو، صفحهٔ الگو را ببینید. دقت کنید که این الگو در اینجا بدون تعریفکردن تمام قابلیتهای آن بهکار رفتهاست، پارامترهای تعریفنشده، مقدارهای پیشفرض خود را بهکار خواهند گرفت.
فاصلههای بهکار رفته در اطراف علامتهای مساوی و پیش و پس از پارامترها تنها برای وضوح بیشتر استفاده شدهاند استفاده از این فاصلهها الزامی نیست و در زمان ارزیابی الگو از آنها چشمپوشی میشود (اگرچه چنین چیزی در خصوص پارامترهای نامگذارینشده صادق نیست). دقت کنید که نام پارامترها به بزرگی و کوچکی حروف حساس هستند. بهعنوان مثال، در نمونهٔ بالا بهجای پارامتر |پایینراست=
میتوان از |DR=
(نمایندهٔ Down Right) نیز استفاده کرد. اما استفاده از dr
یا dR
بهجای آن، امکانپذیر نیست. از پارامترهایی که نام آنها مورد استفادهٔ الگو قرار نگرفتهباشد، بهسادگی چشمپوشی میشود.
با بررسی متن مبدأ الگو، نشانهگذاری استاندارد جدول را بههمراه تعدادی آکولادهای سهقلو مشاهده خواهید کرد که مشخصکنندهٔٔ پارامترها هستند:
{| id="Payoff matrix" style=" float: {{{Float|left}}}; clear:left; text-align:center;" align={{{Float|left}}} cellspacing=0 cellpadding=8 width={{{Width|225}}} |- |style="width:33%; "| |style="width:33%; border-bottom: solid black 1px;"| {{{2R|راست}}} |style="width:33%; border-bottom: solid black 1px;"| {{{2L|چپ}}} |- |style="border-left: solid black 1px; text-align: left; "| {{{1U|بالا}}} |style="border-left: solid black 1px; border-bottom: solid black 1px; font-size:120%; "| {{{UR|۰، ۰}}} |style="border-left: solid black 1px; border-bottom: solid black 1px; font-size:120%; "| {{{UL|۰، ۰}}} |- |style="border-left: solid black 1px; text-align: left; "| {{{1D|پایین}}} |style="border-left: solid black 1px; border-bottom: solid black 1px; font-size:120%; "| {{{DR|۰، ۰}}} |style="border-left: solid black 1px; border-bottom: solid black 1px; font-size:120%; "| {{{DL|۰، ۰}}} |- |style="font-size: 90%;" colspan=3 |''{{{Name| {{PAGENAME}} }}}'' |}
عبارت {{{2L|چپ}}}
به الگو میگوید که از پارامتر نامگذاریشدهٔ 2L
استفاده کند و در صورت موجود نبودن آن در فراخوانی الگو، متن چپ
را نمایش دهد. توجه کنید که چون رابط کاربری ویکیپدیای فارسی «راست به چپ» است، در نتیجه شما دستور را در صفحهٔ ویرایش الگو به این شکل خواهید دید: {{{2L|چپ}}}
. این پارامتر و سایر پارامترها در متن اصلی الگو در واقع بهشکل {{{2L|{{{۲چ|چپ}}}}}}
آمدهاند که در ادامه و در بخش § ایجاد و ویرایش الگوها در خصوص آنها توضیح داده خواهد شد.
توجه به نکات زیر در زمان استفاده از الگوها میتواند مفید باشد:
{{=}}
جایگزین کنید. این الگوی ویژه یک علامت مساوی را برمیگرداند که توسط توابع تفسیر نخواهد شد. شیوهای دیگر برای این کار این است که پارامتر نامگذارینشده (و هرگونه پارامتر نامگذارینشده دیگری) را با پارامترهای نامگذاریشده جایگزین کنید، پارامتر نامگذارینشده اول برابر است با پارامتر نامگذاریشده |۱=
و باقی پارامترهای موضعی نیز به همین ترتیب میتوانند نامگذاری شوند. برای فراخوانی {{شد}}
با عبارت الف=ب
بهعنوان مقداری دقیق برای پارامتر موضعی اول، یکی از عبارتهای {{شد|الف{{=}}ب}}
یا {{شد|1=الف=ب}}
را تایپ کنید.|
نیز در پارامترهای الگوها وجود ندارد؛ چرا که استفاده از آن باعث تفسیر شدنش بهعنوان یک جداکننده میشود. اینبار مشکل را میتوان با استفاده از واژهٔ جادویی {{!}}
بهجای نویسهٔ لوله یا در صورتی که بنا نباشد لوله در سطحی بالاتر تجزیه شود، با استفاده از نهاد اچتیامال |
حل کرد. متناوباً برای تعبیهکردن یک جدولهای ویکی در الگوها، بهمنظور جلوگیری از استفادهٔ بیش از اندازه از {{!}}
میتوانید از {{جدول ویکی}}
استفاده کنید.{{حذف فاصله خالی}}
استفاده کنند){{الگو}}
(یا {{tl}}
که نمایندهٔ «template link» است) انجام داد. برای مثال، {{الگو|نمونه}}
نتیجه میدهد: {{نمونه}}. چندین الگوی پیونددهی به الگو نیز با عملکردهای متفاوت در دسترس هستند. ~~~~~
را تایپ کنید، اما این تنها در صورتی کارساز خواهد بود که الگو را جانشانی کنید. اگر آن را تراگنجانش کنید، فقط عبارت ~~~~~ برگردانده خواهد شد.
پس از آن است که یک کامنت اچتیامال را تولید میکند.ایجاد و ویرایش الگوها بسیار شبیه به ایجاد ویرایش هر صفحهٔ دیگری در ویکیپدیا است: یک نام مناسب را انتخاب کنید، به صفحه بروید، و بر حسب نیاز بر روی «ویرایش» کلیک کنید یا این که صفحه را ایجاد کنید. همانطور که در بالا گفتهشد، الگوها معمولاً در فضای نام الگو قرار میگیرند، با این حال، الگوهایی که برای استفادهٔ شخصی خودتان یا برای مقاصد تمرینی و آزمایشی ایجاد میکنید را میتوانید در فضای کاربری خودتان بسازید. هرآنچه که بتواند در یک صفحه یا مقالهٔ معمولی درج شود، میتواند در یک الگو نیز قرار گیرد. از جمله الگوهای دیگر (شناختهشده با نام زیرالگو). الگوها معمولاً از ویژگیها، پارامترهای برنامهنویسی، توابع تجزیهگر، و سایر کلمات جادویی استفاده میکنند که تنوع محتوای تراگنجانش شده بر پایه موضوع را ممکن میسازد.
پیش از ایجاد یک الگوی تازه، جستجوی مختصر برای الگوهای موجود انجام دهید (مثلاً با بررسی رده:الگو:ویکیپدیا). ممکن است الگویی از پیش موجود باشد که همان کاری که شما مد نظر دارید را انجام دهد یا الگویی مشابه وجود داشتهباشد که بتوانید کد آن را کپی کرده و تغییر دهید (یا آن را در همان جای خود باقی بگذارید و فقط آن را گسترش دهید). بهدنبال الگوهای عمومی باشد که الگوی تازه بتواند بر پایه آن ساختهشود؛ برای مثال، الگوهای جعبه ناوبری را میتوان به راحتی با فراخوانی الگو:Navbox ایجاد کرد.
قاعدهٔ سختگیرانهای برای انتخاب نام یک الگو وجود ندارد، نامی کوتاه انتخاب کنید که در عین حال عملکرد الگو را به خوبی توصیف کند. اگر الگوهایی مشابه موجود هستند، سعی کنید از قالبی مشابه و پایدار برای نامگذاری پیروی کنید. نام الگوها را میتوان با برجای گذاشتن یک تغییرمسیر به نام جدید الگو در زمان انتقال، بدون شکستن تراگنجانشهای موجود تغییر داد.
در زمان ویرایش الگوهای موجود بسیار محتاط باشید، تغییرات اعمالشده در الگوها میتواند بر تعداد زیادی صفحه و معمولاً بهشکلی که انتظارش را ندارید، تأثیر بگذارد. بههمین دلیل، بسیاری از الگوهای پرکاربرد بهگونهای در مقابل ویرایش حفاظت شدهاند که تنها توسط مدیران و ویرایشگران الگو قابل ویرایش باشند؛ سایر ویرایشگران میتوانند در صفحهٔ بحث الگو درخواست ویرایش دهند. برخی الگوها برای انجام ویرایشهای آزمایشی و آزمودن ویرایشهای جدید در صفحهها، دارای یک صفحهٔ تمرین و نمونههای آزمایشی هستند.
برای پیشنهاد حذف یا ادغام الگوهای بدون استفاده یا نامناسب، یا الگوهایی که بهسادگی میتوانند ادغام شوند، الگو را در نظرخواهی برای حذف نامزد کنید.
مقدارهای پارامترهایی که میتوانند به یک الگو خورانده شوند، در کد الگو بهشکل موردهایی قرارگرفته در میان آکولادهای سهقلو تعریف میشوند:
{{{فلان}}}
با مقداری که به پارامتری با نام فلان
داده میشود، جایگزین خواهد شد. این پارامترها با نام پارامترهای نامگذاریشده شناخته میشوند.{{{1}}}
، {{{2}}}
و سایر پارامترهایی که بهصورت اعداد لاتین تعریف میشوند، با مقدار وارد شده در پارامتر نامگذارینشدهٔ اول، دوم و غیره (یا مقدار پارامتر 1
، 2
، و غیره) جایگزین میشوند؛ این پارامترها با نام پارامترهای موضعی شناخته میشوند.اگر یک پارامتر فاقد مقدار باشد، هیچ جایگزینی انجام نخواهد شد؛ به این معنی که اگر مقداری به پارامتر |فلان=
فرستاده نشدهباشد، مقدار عبارت {{{فلان}}}
در درون الگو عیناً برابر با {{{فلان}}} خواهد بود و نه آن فضای «خالی» که انتظارش را دارید. رفتار قابل لمستر الگو میتواند با تعریف مقدارهای پیشفرض برای پارامترها حاصل شود. این کار را میتوان با نحو لولهای انجام داد: {{{فلان|پیشفرض}}}
که مقدار پیشفرض پیشفرض
را برای پارامتر نامگذاریشده |فلان=
تعریف میکند و {{{1|پیشفرض}}}
که مقدار پیشفرض پیشفرض
را برای پارامتر نامگذارینشده اول تعریف میکند. در اغلب اوقات، از این قابلیت برای تعریفکردن مقدارهای پیشفرض خالی، نظیر {{{1|}}}
یا {{{فلان|}}}
استفاده میشود.
نامهای مستعار پارامترها حالتی ویژه از مقدارهای پیشفرض هستند. برای مثال، اگر پارامتر |۱=
، |متن=
و |پیام=
همگی نامی برای یک پارامتر باشند، ویکیمتن {{{پیام|{{{متن|{{{1|}}}}}}}}}
را میتوان بهکار گرفت. اگر بیشتر از یکی از این پارامترها دارای مقدار باشد، آنگاه پارامتر پیام
اولویت خواهد داشت و پس از آن متن
و در نهایت نخستین پارامتر نامگذارینشده دارای اولویت خواهند بود. به این معنی که اگر پارامترهای |پیام=الف|متن=ب
به الگوی دارندهٔ این ویکیمتن فرستاده شود، ویکیمتن الگو بهشکل الف
بسط خواهد یافت.
بهدلیل استفادههای چندباره از نحو دارای آکولادها دوقلو و سهقلو، عبارتهای بعضی مواقع ممکن است ابهامدار باشند. برای حل این ابهام، قرار دادن فاضله میان این آکولادها میتواند مفید باشد. برای مثال، {{{{{فلان}}} }}
یا {{{ {{فلان}} }}}
بهجای درج پنج آکولاد متوالی، میتواند برای انسان بیشتر قابل خواند باشد. با این حال، دقت کنید که فاضلهٔ خالی ناخواسته ممکن است در زمان بسط الگو در خروجی آن نمایش داده شود.
پارامترها، در صورتی که در ماین برچسبهای <nowiki>
قرار گیرند، بسط نخواهد یافت. بهطور مشابه، پارامترها در صورت قرار گرفتن در یک برچسب گشایندهٔ واقعی بهسبک اکسامال نیز بسط نمییابند. ار این روی، عبارت زیر اگر در یک الگو قرار گیرد، کار نخواهد کرد:
چرا که پارامتر وارد شده در برچسب بسط نخواهد یافت. در عوض، میتوانید از تابع تجزیهگر {{#tag:}}
استفاده کنید که برای مثال در {{sfn}}
و بهمنظور ایجاد عنصر ...
بهکار رفتهاست؛ همچنین راهنما:کلمات جادویی § قالببندی را ببینید؛ بنابراین، نمونهٔ زیر بهخوبی کار خواهد کرد:
اگر مقدار یک پارامتر یک نشانی اینترنی است (یا به آن ختم میشود)، با افزودن یک یا چند نویسه به انتهای نشانی اینترنتی–که باعث میشود کلیککردن روی پیوند منجر به خطا یا واماندگی شود–بررسی کنید که آن نشانی با گسترش بیش از اندازهٔ پیوند در ویکیپدیا نمایش خواهد یافت یا خیر. اطمینان حاصل کنید که پس از پردازش توسط نرمافزار، صرف نظر از این که نشانی از سوی شما یک کاربر دیگر وارد شده یا بهواسطهٔ پردازش خودکار تولید شده، یک فاصلهٔ نرم (و نه یک فاصلهٔ سخت یا نشکن) بهدنبال نشانی بیاید. احتمالاً کد مبدأ میتواند شامل یا تولیدکنندهٔ فاصلهای باشد که در زمان پردازش حذف میشود، یا این که ممکن است هیچ فاصلهای در این کد موجود نباشد. کد مبدأ را، مثلاً با افزودن یک فاصلهٔ نرم پس از نشانی، بهصورت دستی تصحیح کنید. الگوی {{فاصله}}
میتواند برای این کار مفید باشد.
کد الگوها معمولاً برای وابستهکردن رفتار الگو به محیط (نظیر زمان کنونی با فضای نام) یا به مقدارهای پارامترهایی که به آنها فرستاده میشوند، از متغیرها و توابع تجزیهگری که در راهنما:کلمات جادویی توصیف شدهاند، استفاده میکنند. از این موارد میتوان در برآوردهای حسابی نیز استفاده کرد، اما ویژگیهای مهم و استاندارد برنامهنویسی مانند حلقهها و انتساب متغیرها در دسترس نیستند. دستکاری کامل رشتهها نیز قابل دسترسی نیست؛ برخی الگوهایی که چنین عملکردی را ارائه میدهند تاکنون ایجاد شدهاند، اما بهصرفه و کامل نیستند.
برخی از پرکاربردترین متغیرها و توابع در زیر فهرست شدهاند. برای یافتن متغیرها و توابع بیشتر، راهنما:کلمات جادویی و مستندات کاملتر در صفحههای mw:Help:Magic words و mw:Help:Extension:ParserFunctions در مدیاویکی را ببینید. این توابع و کلمات جادویی دارای نام مستعار فارسی نیز هستند که در جدول زیر به آنها اشاره شدهاست. دقت کنید که در بسیاری از این نامهای مستعار فارسی، بهجای استفاده از فاصله، از نیمفاصله استفاده شدهاست.
توصیف | متن ورودی | نتیجه |
---|---|---|
تبدیل متن به حروف بزرگ (برای حروف لاتین) | {{uc: Heavens to BETSY!}} {{ب: Heavens to BETSY!}} | HEAVENS TO BETSY! |
تبدیل متن به حروف کوچک (برای حروف لاتین) | {{lc: Heavens to BETSY!}} {{ک: Heavens to BETSY!}} | heavens to betsy! |
دریافت نام یک فضای نام | {{NS: 1}} {{فن: 1}} | الگو:فن: ۱ |
دریافت نشانی اینترنتی در ویکیپدیا | {{fullurl: pagename}} {{نشانیکامل: pagename}} | //fa.wikipedia.org/wiki/Pagename |
افزونهٔ ParserFunctions توابع تجزیهگر بیشتری با محوریت برنامهنویسی را ارائه میدهد.
توصیف | متن ورودی | نتیجه |
---|---|---|
آزمودن برابری میان دو رشته (یا پارامتر) | {{#اگرمساوی: بله | بله | هورا...! | ای بابا...!}} | هورا…! |
{{#اگرمساوی: بله | خیر | هورا...! | ای بابا...!}} | ای بابا…! | |
آزمودن این که یک رشته (یا پارامتر) دربردارندهٔ چیزی (بهجز فاصله خالی) هست یا خیر | {{#if: {{{param|}}} | Hooray...! | Darn...! }} {{#اگر: {{{پارامتر|}}} | هورا...! | ای بابا...! }} | ای بابا…! |
انجام یک محاسبه (ریاضی) [مساحت دایرهای به شعاع ۴، تا ۳ رقم اعشار] [ارقام فارسی نمیپذیرد و ارقام باید به لاتین وارد شوند] [نتیجه با اعداد انگلیسی خواهد بود و برای دریافت ارقام فارسی، باید کل عبارت را به واژه جادویی آرایشعدد فرستاد] | {{#expr: ( pi * 4 ^ 2 ) round 3}} {{#حساب: ( pi * 4 ^ 2 ) round 3}} {{آرایشعدد: {{#حساب: ( pi * 4 ^ 2 ) round 3}} }} | 50.265 ۵۰٫۲۶۵ |
آزمودن نتیجهٔ یک محاسبه [عدد ۱۲۳۰ فرد است یا زوج؟] | {{#ifexpr: 1.23E+3 mod 2 | Odd | Even}} {{#اگرحساب: 1.23E+3 mod 2 | فرد | زوج}} | Even زوج |
توصیف | متن ورودی | نتیجه (برای همین صفحهٔ راهنما) |
---|---|---|
نام صفحهها | {{PAGENAME}} {{نامصفحه}} | الگو |
{{FULLPAGENAME}} {{نامکاملصفحه}} | راهنما:الگو | |
نام فضای نام کنونی | {{NAMESPACE}} {{فضاینام}} | راهنما |
تعداد کاربران ثبتنام کرده | {{NUMBEROFUSERS}} {{تعدادکاربران}} | ۱٬۳۰۶٬۱۶۰ |
تعداد صفحهها در یک ردهٔ خاص | {{PAGESINCATEGORY:آلبومهای محمدرضا شجریان}} {{صفحهدررده:آلبومهای محمدرضا شجریان}} | ۷۴ |
نسخهٔ کنونی نرمافزار | {{CURRENTVERSION}} {{نسخهکنونی}} | 1.43.0-wmf.2 (ce9d259) |
برچسب زمانی آخرین نسخهٔ صفحه | {{REVISIONTIMESTAMP}} {{زماننسخه}} | 20231126144252 |
متغیرهای {{نامصفحه}}
و {{فضاینام}}
منحصراً مفید هستند و بارها برای تغییر رفتار الگو بر پایه زمینه بهکار رفتهاند. برای مثال، اگر الگو برای تراگنجانش پیوند یک رده بهکار رود (مثلاً ردههای تمیزکاری که پیوندی را برای ردهبندی صفحه بهعنوان یک صفحهٔ نیازمند توجه تراگنجانش میکنند)، معمولاً متغیر {{فضاینام}}
را بررسی میکند تا مطمئن شود که صفحههای بحث، صفحههای کاربری یا هر فضای نام دیگری که ممکن است برچسب بهطور تصادفی و ناخواسته در آنها قرار گرفتهباشد، خود بهعنوان صفحههای نیازمند تمیزکاری ردهبندی نشوند.
الگوها ممکن است الگوهایی دیگر را در خود داشتهباشند، به این حالت معمولاً ساختار تودرتویی میگویند. هرگاه الگو پردازش شود، ویکیمتن تولیدشده توسط هر الگوی تودرتویی دیگر در داخل الگوی اصلی تراگنجانش میشود و در نتیجه پردازش محصول نهایی اساساً از پایینترین سطح از الگوهای تودرتو آغاز میشود. اگرچه استفادهٔ این الگوها بسیار ساده است، اما ایجاد آنها نیازمند بهکارگیری ترفندها و فنون پر جزئیات است.
برای فرستادن یک پارامتر به یک الگوی تودرتو، برچسب پارامتر را بهعنوان مقداری برای پارامترهای الگوی تودرتو در ویکیمتن الگو درج کنید.
«{{ب|{{{3}}} }} قهوهایرنگ چابک از روی...»
است. این عبارت، مقدار فرستادهشده به پارامتر مکانی سومِ الگو:الف را میگیرد و آن را به پارامتر مکانی اولِ الگو:ب میفرستد؛ سپس متن تولیدشده توسط الگو:ب را بهعنوان بخشی از عبارت برمیگرداند.«{{ب|والدو={{{3}}} }} قهوهایرنگ چابک از روی...»
است. اینجا هم عملکرد الگو:الف مانند مثال قبلی است، با این تفاوت که پارامتر مکانی سومِ الگو:الف به پارامتر نامگذاریشدهٔ |والدو=
در الگو:ب فرستاده میشود.پارامترهای الگو خود میتوانند بهصورت مشروط انتخاب شوند.
«{{ب|{{{3}}}=روباه }} قهوهایرنگ چابک از روی...»
است. الگو:الف کلمهٔ «روباه» را به پارامتر نامگذاریشدهای از الگو:ب میفرستد که نام آن برابر با پارامتر مکانی سوم الگو:الف است.{{#اگر: رشته آزمون | مقدار در صورت خالی نبودن رشته آزمون | {{#اگر: رشته آزمون | مقدار در صورت خالی نبودن رشته آزمون | مقدار در صورت خالی بودن رشته آزمون (یا تنها فاصله خالی) }} }}
هر الگو میتواند خودش را فراخوانی کند، اما این روند پس از یک بار تکرار متوقف خواهد شد تا از تشکیل یک حلقهٔ بیپایان جلوگیری شود.
وقتی یک الگوی تودرتویی دربردارندهٔ آکولادهای نامتناظر باشد مانند آنچه کد {{lb}}}
آکولادهای نامتناظر در زمان پردازش بهعنوان متن در نظر گرفته میشوند و بر روی تجزیهٔ آکولادهای الگوی داخلی اثر نخواهند گذاشت. با این حال، اگر الگوی داخلی جانشانی شود، ابتدا عمل جانشانی پردازش می شود و این باعث تغییر نحوهٔ تجزیهٔ آکولادها در الگوی داخلی خواهد شد. این عمل، کاربرد چندانی ندارد، اما بعضی اوقات میتواند باعث بروز خطاهایی دور از انتظار شود.
برای اطلاعات بیشتر، صفحههای راهنمای الگوهای پیشرفته و راهنمای تبدیل بازگشتی ویکیمتن| در فراویکی را ببینید. این صفحهها شامل اطلاعاتی پیرامون فراخوانیهای غیرمعمول نظیر {{الگو {{{پارامتر|}}} }}
نیز هستند.
هرگاه یک الگو تراگنجانش یا جانشانی شود، بهطور پیشفرض کل ویکیمتن (کد) صفحهٔ الگو در ویکیمتن صفحهٔ مقصد گنجانده میشود. با این حال، امکان تغییر این رفتار با استفاده از برچسبهایی که برای مشخصکردن بخشهایی خاص از الگو جهت گنجاندن بهکار میروند، وجود دارد. این برچسبها امکان جلوگیری از تراگنجانش اطلاعاتی مانند {{توضیحات}} الگو، ردهها و پیوندهای میانویکی که تنها برای نمایش در صفحهٔ خود الگو ایجاد شدهاند را فراهم میکند. همچنین میتوان بخشهایی از الگو را تراگنجانش کرد، اما از پردازش آن در صفحهٔ خود الگو جلوگیری کرد (برای مثال، ردههایی که باید در صفحهٔ مقصد الگو قرار گیرند، اما شامل حال خود الگو نمیشوند). این برچسبها به شرح زیر هستند:
<noinclude>...
– متن موجود در میان این برچسبها در زمان تراگنجانش (یا جانشانی)، در متن خروجی الگو شامل نخواهد شد، اما در صفحهٔ خود الگو پردازش خواهد شد؛ کاربرد معمول این برچسبها اغلب برای مستندات الگوها دیده میشود.<onlyinclude>...
– این برچسب مشخص میکند که هیچچیز بهجز آنچه در میان این برچسبها قرار گرفته، تراگنجانش (یا جانشانی) نخواهد شد.<includeonly>...
– متنی که در میان این برچسبها قرار گیرد تراگنجانش (یا جانشانی) خواهد شد، اما در صفحهٔ خود الگو پردازش نخواهد شد.ویکیمتن | آنچه در همینجا (صفحهٔ مبدأ) ارائه میشود | آنچه در آنجا (صفحهٔ مقصد) تراگنجانش میشود |
---|---|---|
| متن۱ متن۲ | متن۲ |
| متن۱ متن۲ | متن۱ |
| متن۲ | متن۱ متن۲ |
| متن۲ | متن۱ |
میتوان گفت که رایجترین مشکل در استفاده از این عبارتها، وجود فاصلهها و خطوط جدید ناخواسته است. لازم است بهیاد داشتهباشید که تأثیر این برچسبها بلافاصله قبل از نخستین پرانتز شکسته آغاز میشود، نه در سطر قبلی یا در نویسهٔ مرئی قبلی؛ همچنین تأثیر آنها بلافاصله پس از آخرین پرانتز شکسته پایان مییابد و نه در سطر بعدی یا نویسهٔ مرئی بعدی. برای مثال:
<includeonly>
<noinclude>
<noinclude>
این برچسبها را میتوان بهصورت تودرتویی با یکدیگر بهکار برد، اگرچه (در یک صفحهٔ مشخص) این قاعده تنها به برچسبهای <onlyinclude>
اعمال میشود؛ استفاده از برچسبهای <includeonly>
و <noinclude>
بهصورت تودرتویی نسبتاً بیهوده است. با این حال، سعی کنید از ساختار تودرتویی مناسب برای این برچسبها استفاده کنید. ساختارهایی نظیر <onlyinclude>
آبپ<includeonly>
تثجچحخ
مطابق با انتظار کار نخواهند کرد. از قاعدهٔ «اولی باز، آخری بسته» که استانداردی در اچتیامال/اکسامال است، استفاده کنید.
:
، ;
، *
، #
باشد، بهگونهای پردازش خواهد شد که گویی در ابتدای سطر قرار گرفتهاست؛ حتی در صورتی که برچسب الگو چنین نباشد. این قابلیت، امکان ایجاد انواع مختلفی از فهرستها را در الگوهایی که ممکن است همیشه در جای درستی برای ایجاد یک فهرست قرار نگیرند، فراهم میکند. برای جلوگیری از چنین چیزی، از <nowiki />
پیش از نشانهگذاری یا بهترتیب از موجودیتهای اچتیامال :
، ;
، *
و #
استفاده کنید. در برخی موارد، در صورت عدم کارایی برچسبهای
، موجودیتهای اچتیامال بهخوبی کار خواهند کرد. این مشکل معمولاً در مواقعی بروز میکند که مقدار یک پارامتر در یک فراخوانی الگو با یکی از این چهار نویسه آغاز شود.{{برداشتن فاصله خالی}}
برای حذف فاصلهها از ابتدا و انتهای مقدار استفاده کرد؛ فاصلههای خالی در ابتدا و انتهای مقدارهای فرستادهشده به پارامترهای نامگذاریشده بهطور خودکار حذف میشوند.جا:
استفاده کنید. این کار میتوان برای درک بهتر این که در زمان تراگنجانش الگو چه اتفاقی میافتد، کمککننده خواهد بود؛ راهنما:جانشانی را ببینید.msgnw:
(کوتاهشدهٔ عبارت «message, nowiki») یا پیغامبیبسط:
استفاده کنید. این کار نقصهایی دارد: فهرستها پردازش میشوند، حاشیهنویسیها حذف میشوند و سطرهای جدید با فاصلهٔ خالی جایگزین میشوند (که بهویژه در زمان تراگنجانش جدولهای ویکیمتنی، گیجکننده خواهد بود).NewPP limit report
بررسی کرد.=
برای ایجاد عنوان بخش استفاده نکنید؛ استفاده از این نویسه یک پیوند [ویرایش]
تولید میکند که در صورت تراگنجانش، بهطور گیجکنندهای صفحهٔ الگو را برای ویرایش باز خواهد کرد. __بیبخش__
(یا __NOEDITSECTION__
) از ایجاد پیوندهای [ویرایش]
به مقصد صفحهٔ الگو جلوگیری کنید.ردهبندی الگو و مستندسازی نحوهٔ صحیح استفاده از آن میتواند به سایر ویرایشگران در یافتن و استفاده از الگوی شما کمک کند.
مستندسازی برای کاربران، در کنار ردهبندی الگو معمولاً پس از کد اصلی الگو و در میان برچسبهای
قرار میگیرد. معمولاً لازم است که برچسب گشایندهٔ
را بلافاصله پس از پایان کد الگو قرار دهید و برای اجتناب از تراگنجانش فاصلههای خالی ناخواسته، هیچ فاصله یا سطر جدیدی نیز پیش از این برچسب درج نکنید.
در الگوهای پیچیده، مستندات بههمراه ردهها معمولاً در یک زیرصفحهٔ جداگانه از صفحهٔ الگو (با عنوان «الگو:فلان/توضیحات») نگهداری میشوند. این قاعده بر بسیاری از الگوهای حفاظتشده نیز اعمال میشود و امکان ویرایش اطلاعات آنها را برای کاربران غیرمدیر نیز فراهم میکند. این زیرصفحه را میتوان با قرار دادن الگوی {{توضیحات}}
پس از کد اصلی الگو و درون برچسبهای
در صفحهٔ اصلی الگو فراخوانی کرد. اگر زیرصفحهٔ «/توضیحات» موجود نباشد، پیوندی برای ایجاد آن در جعبهٔ مستندات الگو نمایش خواهد یافت.
بعضی الگوها دربردارندهٔ ردههای تعریفشدهای در کد قابل تراگنجانش خود هستند تا صفحهٔ مقصد را در یک رده(هایی) خاص قرار دهند. چنین چیزی معمولاً در الگوهای نگهداری دیده میشود (قرار دادن مقالهها در ردههای محتوایی عادی توصیه نمیشود). در زمان ایجاد چنین الگوهایی، لازم است که که از برچسبهای
استفاده کنید تا از قرار گرفتن صفحهٔ خود الگو در ردهٔ مورد نظر جلوگیری شود. در زمان توسعه، آزمودن، تمرینکردن یا ارائهٔ الگویی که بهمنظور افزودن یک رده ساخته شده، هر یک از ردهها را با یک ردهٔ آزمایشی (مثلاً ت۱ و در صورت نیاز، با تولید نمونههایی با شمارههای بالاتر) جایگزین کنید یا ردهبندی را فرونشانی کنید (فرونشانی رده در الگوها را ببینید).
تعریف ردهبندی بهشکل [[رده:الگو:موضوع مورد نظر]]
باید در صفحهٔ مستندات الگو (یا در صورت نبود صفحهٔ مستندات، درون برچسبهای
) قرار داده شود تاز از آلوده شدن صفحههایی که الگو را تراگنجانش میکنند جلوگیری شود.
نامهای مستعار را میتوان با کمک تغییرمسیرها ایجاد کرد. برای مثال، الگو:مفبا به الگوی الگو:ماه فارسی به انگلیسی تغییر مسیر دارد. در نتیجه میتوانید برای استفاده از این الگو عبارت {{مفبا|فلان}}
را بهجای {{ماه فارسی به انگلیسی|فلان}}
بنویسید.
بد نیست که نامهای مستعاری که تنها در فاصلههای خالی یا نحوهٔ نوشتن عنوان با نام اصلی تفاوت دارند را نیز تهیه کنید. برای مثال، الگوی {{رده انبار}}
دارای نامهای مستعار {{انبار رده}}
و {{انبار-رده}}
نیز هست. چرا که ممکن است کاربران نام این الگو را به شکلهای مختلفی بنویسند. همچنینی برای الگوهایی که از عنوان انگلیسی استفاده میکنند نیز میتوان چنین نامهای مستعاری ایجاد کرد. بهعنوان مثال، الگوی {{See Wiktionary}}
را در نظر بگیرید. حرف «W» در عنوان آن بهصورت بزرگ نوشتهشده؛ چرا که حرف اول نام «Wiktionary» نیز چنین است. اما تغییرمسیر {{See wiktionary}}
با «w» کوچک نیز موجود است. زیرا ممکن است کاربران نام آن را به این شکل نیز بنویسند.
محدودیت «اندازه دربرگیری پس از بسط». هرگاه یک الگو برای مشاهده در مرورگر شما در قالب اچتیامال ارائه یا بسط داده میشود از ظرفیت حافظهٔ شما استفاده میکند. این را با نام «اندازه دربرگیری پس از بسط» (انگلیسی: Post-expand include size) میشناسند و محدودیت آن برابر با ۲٬۰۴۸٬۰۰۰ بایت است. این اندازه بهشکل حاشیهنویسی مخفی در خروجی اچتیامال نمایان میشود، برای نمایش اچتیامال خام، از ویژگی مشاهدهٔ مبدأ مرورگر خود استفاده کنید و عبارت «newpp» را جستجو کنید. گزارشی که مشاهده خواهید کرد، مشابه متن زیر است:
این نمونه نشاندهندهٔ این است که بسط الگو ۶۳٬۴۷۶ بایت از ۲٬۰۴۸٬۰۰۰ بایت حافظهٔ در دسترس را استفاده کردهاست.
مشکل نمایش. اگر تعداد بسیار زیادی الگو در یک صفحه گنجانده شوند، اندازه دربرگیری پس از بسط ممکن است از محدودیت عبور کند. هرگاه چنین شود، الگوهای بعد از محدودیت دیگر بسط نخواهند یافت و در عوض بهشکل یک ویکیپیوند نمایش خواهند یافت (برای مثال، الگو:نام الگو). دلیل معمول برای این اتفاق، استفادهٔ بسیار زیاد از الگوهای یادکرد و/یا الگوهای پرچم است. برای رفع این مشکل، الگوها را جانشانی کنید، الگوهایی را حذف کنید، یا صفحه را تفکیک کنید.
تراگنجانشهای ارائهنشده هم بر رسیدن به محدودیت اثرگذارند. برای مثال، صفحهای که تنها شامل {{#اگر:{{:صفحهٔ اصلی}}}}
باشد، همچنان دارای اندازهٔ دربرگیری پس از بسط است؛ حتی اگر هیچگونه خروجی نداشتهباشد.
همین قاعده بر پودمانها اسکریبونتو نیز اعمال میشود. برای مثال، {{#invoke:Test|main}}
همچنان اندازهٔ دربرگیری پس از بسط را افزایش میدهد؛ حتی اگر کد پودمان:Test تنها بهشکل زیر بودهباشد:
mw.getCurrentFrame():preprocess "{{پیغامبیبسط::صفحهٔ اصلی}}" -- remove this line and post-expand include size becomes zero return {main = function() end} -- p.main() has no return value
از فوریهٔ ۲۰۱۳، زبان برنامهنویسی لوآ برای استفاده بهواسطهٔ افزونهٔ اسکریبونتوی مدیاویکی در دسترس است. کد لوآ را میتوان با بهکارگیری تابع {{#درخواست:}}
یا {{#invoke:}}
از افزونهٔ اسکریبونتوی مدیاویکی، در الگوها تعبیه کرد. کد منبع لوآ در صفحههایی که پودمان نامیده میشوند، ذخیره میشود و این پودمانها در صفحههای الگوها فراخوانی میشوند. برای مثال، پودمان:نمونه را میتوان با استفاده از کد {{#درخواست:نمونه|hello}}
فراخوانی کرد تا متن «سلام دنیا!» را نمایش دهد.
میتوانید با استفاده از جعبهٔ ویژه:جستجو در پایین، در فضای نام الگو الگوی موردنظرتان را جستجو کنید:
صفحههای راهنما | صفحههای شیوهنامه | صفحههای ویژه | صفحههای برای مشاهده غیرمستقیم |
---|---|---|---|
|
|
|
This article uses material from the Wikipedia فارسی article راهنما:الگو, which is released under the Creative Commons Attribution-ShareAlike 3.0 license ("CC BY-SA 3.0"); additional terms may apply (view authors). محتوا تحت CC BY-SA 4.0 در دسترس است مگر خلافش ذکر شده باشد. Images, videos and audio are available under their respective licenses.
®Wikipedia is a registered trademark of the Wiki Foundation, Inc. Wiki فارسی (DUHOCTRUNGQUOC.VN) is an independent company and has no affiliation with Wiki Foundation.