Jump to content

Extension:Variables

From mediawiki.org
This page is a translated version of the page Extension:Variables and the translation is 93% complete.
Outdated translations are marked like this.
MediaWiki manüel uzantıları
Variables
Sürüm durumu: kararlı
Uygulama Ayrıştırıcı işlevi
Açıklama Sayfa kapsamındaki değişkenlerle başa çıkmak için ayrıştırıcı işlevlerini tanıtır.
Yazar(lar)
Sürdürücü(ler) MGChecker
En son sürüm 2.5.1 (2019-07-11)
MediaWiki 1.29+
PHP 5.5+
Veritabanı değişiklikleri Hayır
Lisans ISC Lisansı
İndir
README
RELEASE-NOTES
  • $wgVariablesAreVolatile
  • $wgVariablesDisabledFunctions
Quarterly downloads 80 (Ranked 59th)
Public wikis using 1,808 (Ranked 201st)
Translatewiki.net adresinde mevcutsa, Variables uzantısını çevirin
Vagrant rolü variables
Sorunlar Açık görevler · Hata bildir
Uyarı Uyarı: This extension is incompatible with plans to parallelize parsing, as is intended by the use of Parsoid . Therefore, the future of this extension is uncertain, and it is expected to become incompatible with the standard MediaWiki parser within a few years. For further information, see görev T250963 and No support for sequential, in-order processing of extension tags .
To avoid deprecation warning about the InternalParseBeforeSanitize hook for MediaWiki 1.35 - MediaWiki 1.38 , or missing the #var_final parser function in MediaWiki 1.39 +, please update to the latest version (master branch for now). Daha fazla bilgi için görev T276627 ve görev T250963 sayfasına bakın.

Variables uzantısı, bir sayfada bir değişken tanımlamanıza, bunu daha sonra aynı sayfada veya eklenen şablonlarda kullanmanıza, değerini değiştirmenize, muhtemelen bir ifade tarafından eski değer açısından verilen bir değere değiştirme vb.

Bir şablona çok benzer, sadece çok hafif ve yalnızca tek bir sayfaya yayılmıştır, bu nedenle vikiyi çok sayıda şablonla yavaşlatmadan bir sayfada birçok değişkeni kullanabilirsiniz. En iyi sonuçlar için bu uzantıyı ParserFunctions uzantısıyla birleştirin.

Bu uzantı, Wikimedia Vakfı (WMF) tarafından yürütülen vikiler için etkinleştirmeyecektir.[1][2][3][4] Alternatifleri bakınız.

Bir değişkene değer atama

#vardefine

  • {{#vardefine:değişkenadı | belirlenmişdeğer }}

değişkendeğeri değerini (zaten var olan veya bu şekilde tanıtılan) değişken değişkenadı atar.

  • Örnek: {{#vardefine:iconwidth|25}}, iconwidth = 25 yapılır

#vardefineecho

  • {{#vardefineecho:değişkenadı | belirlenmişdeğer }}

Tam olarak #vardefine olarak çalışır, ancak etkilenen değer yazdırılır.

  • Örnek: iconwidth = {{#vardefineecho:iconwidth|25}} yapılır

Bir değişkenin değerini alma

#var

değişkenadı değişkeninin değeri şu şekilde üretilir:

  • {{#var:değişkenadı}}

Tanımsızsa, bu boş bir dize oluşturur; bir hata mesajı vermez.

Değişkenin tanımsız veya geçersiz olduğu durum için bir değer tanımlamak mümkündür:

  • {{#var:değişkenadı | varsayılandeğer }}

Bu şuna eşittir:

  • {{#if: {{#var:değişkenadı }} | {{#var:değişkenadı }} | varsayılandeğer }}

ancak çok daha kısa ve daha iyi düzenlenmiş. Sürüm 2.0'dan önce, varsayılan değer her zaman genişletildi. Varsayılan sürüm 2.0 sürümünden yalnızca gerçekten kullanılması durumunda genişletilir.

Değer ayrıştırıcı işlevlerinde vb. kullanılabilir.

#varexists

  • {{#varexists:değişkenadı }} değişken önceden tanımlanmışsa 1 değerini döndürür. Değişken tanımlanmamışsa dönüş değeri geçersizdir.

Bu değerleri değiştirmek için ikinci ve üçüncü bir parametreyi destekler.

  • {{#varexists:değişkenadı | değer-ise | başka-bir-değer }}

Bu şuna eşittir:

  • {{#if: {{#varexists: değişkenadı }} | değer-ise | başka-bir-değer }}

ancak çok daha kısa ve daha iyi düzenlenmiş. 2.5 sürümünden önce, her ikisi de her zaman genişletildi. 2.5 sürümünden if ve else değerleri yalnızca durumları gerçekten girildiğinde genişletilir.

#var_final

Variables 2.0'da tanıtılan deneysel işlev. Bu işlev, sayfa görüntülemenin sonunda bir değişkenin sahip olduğu son, son değeri verir. Doğal olarak, değer, ayrıştırıcı tüm viki biçimlendirmesinin üzerinden geçtikten sonra eklenecektir, bu nedenle bu işlev, doğru değerin kullanılması beklendiğinden diğer işlevlerde kullanılamaz. Örnek:

  • {{#var_final:değişkenadı | varsayılandeğer }}

Değişken son sayfa oluşturma aşamasında yoksa veya değeri boş bir dize ise default değer kullanılır. Varsayılan, işlevin kullanıldığı yerde genişletilir, böylece parametre gerekmeyecek olsa bile genişletilir.

Örnekler

#expr kullanmak için ParserFunctions uzantısının da yüklenmesi gerekir.

x = 2*a + b hesapla:

  • {{#vardefine:x|{{#expr:2*{{#var:a}}+{{#var:b}}}}}}

n olarak bir tane ekleyin:

  • {{#vardefine:n|{{#expr:{{#var:n}}+1}}}}

Kurulum

  • Dosyaları indirin ve extensions/ klasörünüzdeki Variables adlı dizine yerleştirin.
    Developers and code contributors should install the extension from Git instead, using:cd extensions/
    git clone https://gerrit.wikimedia.org/r/mediawiki/extensions/Variables
  • LocalSettings.php dosyanızın altına aşağıdaki kodu ekleyin:
    wfLoadExtension( 'Variables' );
    
  • Gerektiği gibi yapılandırın
  • Yes Yapıldı – Uzantının başarıyla yüklendiğini doğrulamak için vikinizde Special:Version seçeneğine gidin.

Yapılandırma

Bu uzantı iki yapılandırma parametresi sağlar:

$egVariablesAreVolatile
Uzantı tarafından geçici olarak işaretlenen ayrıştırıcı çerçevesinin devre dışı bırakılmasına izin verir, yani şablon önbelleğini devre dışı bırakır.
Varsayılan: true;
$egVariablesDisabledFunctions
Bu uzantı tarafından sağlanan belirtilen ayrıştırıcı işlevlerini devre dışı bırakmaya izin verir.
Varsayılan: [];
Örnek: [ 'var_final', 'vardefineecho' ];

Uyumluluk

Son MediaWiki sürümleri için Değişkenler uzantısının önerilen sürümü aşağıda listelenmiştir. Uzantıların eski sürümleri de işe yarayabilir, ancak yeni MediaWiki sürümleri için test edilmemiştir.


Alternatifler

Bu uzantı, Wikimedia Foundation (WMF) tarafından çalıştırılan vikiler için etkinleştirilmeyeceğinden, işte bazı alternatifler:[1][2][3][4]

  • Değişkenleri pahalı işlemler için önbellek olarak kullanırsanız, ihtiyaç duyduğunuz bölümü bir şablona dönüştürebilir ve bunun yerine gerekli bilgileri şablon parametreleri olarak iletebilirsiniz. Bu, genişleme derinliği sınırına ulaşana kadar çalışır. This will work until you reach the expansion depth limit, which can be increased if necessary.
  • Değişkenleri basit Extension:ParserFunctions ile mümkün olandan daha karmaşık şablon işlemleri yapmak için kullanırsanız, bunun yerine Scribunto'nun Lua işlevini kullanabilirsiniz. Bunun genel Değişkenler için destek eklemediğini unutmayın. Ancak, Extension:VariablesLua , Variables deposu için bir Scribunto arabirimi ekler.
  • Değişken kullanmayın, bunun yerine ihtiyacınız olan bilgiyi değişken olarak çoğaltın. Bu bilgiler pahalı bir şablon çağrısı tarafından alınırsa, performans düşebilir. Bu, düğüm sayısı sınırına ulaşana kadar çalışacaktır.
  • If you require variables just for autonumbering, you could look into Extension:NumerAlpha .

Ayrıca bakınız

Kaynakça