Geliştiriciler için Uygulamalar
Kurulum
Latte'yi kurmanın en iyi yolu bir Composer kullanmaktır:
composer require latte/latte
Desteklenen PHP sürümleri (en son yama Latte sürümleri için geçerlidir):
sürüm | PHP ile uyumlu |
---|---|
Latte 3.0 | PHP 8.0 – 8.2 |
Bir Şablon Nasıl Oluşturulur
Bir şablon nasıl oluşturulur? Sadece bu basit kodu kullanın:
$latte = new Latte\Engine;
// önbellek dizini
$latte->setTempDirectory('/path/to/tempdir');
$params = [ /* template variables */ ];
// veya $params = new TemplateParameters(/* ... */);
// çıktıya render et
$latte->render('template.latte', $params);
// veya değişkene dönüştürme
$output = $latte->renderToString('template.latte', $params);
Parametreler diziler veya daha da iyisi nesne olabilir, bu da editörde tür denetimi ve öneri sağlayacaktır.
Kullanım örneklerini Latte examples deposunda da bulabilirsiniz.
Performans ve Önbellekleme
Latte şablonları son derece hızlıdır, çünkü Latte bunları doğrudan PHP koduna derler ve diskte önbelleğe alır. Bu nedenle, saf PHP ile yazılmış şablonlara kıyasla ekstra ek yükleri yoktur.
Kaynak dosyayı her değiştirdiğinizde önbellek otomatik olarak yeniden oluşturulur. Böylece geliştirme sırasında Latte şablonlarınızı rahatça düzenleyebilir ve değişiklikleri hemen tarayıcıda görebilirsiniz. Bu özelliği üretim ortamında devre dışı bırakabilir ve performanstan biraz tasarruf edebilirsiniz:
$latte->setAutoRefresh(false);
Bir üretim sunucusuna yerleştirildiğinde, özellikle büyük uygulamalar için ilk önbellek oluşturma işlemi anlaşılabilir bir şekilde biraz zaman alabilir. Latte önbellek izdihamına karşı yerleşik bir önleme sahiptir. Bu, sunucunun çok sayıda eş zamanlı istek aldığı bir durumdur ve Latte'nin önbelleği henüz mevcut olmadığından, hepsi aynı anda oluşturacaktır. Bu da CPU'yu yükseltir. Latte akıllıdır ve birden fazla eşzamanlı istek olduğunda, yalnızca ilk iş parçacığı önbelleği oluşturur, diğerleri bekler ve sonra kullanır.
Sınıf Olarak Parametreler
Değişkenleri şablona diziler olarak geçirmekten daha iyisi bir sınıf oluşturmaktır. Tip güvenli gösterim, IDE'de güzel öneri ve filtreler ile fonksiyonları kaydetmek için bir yol elde edersiniz.
class MailTemplateParameters
{
public function __construct(
public string $lang,
public Address $address,
public string $subject,
public array $items,
public ?float $price = null,
) {}
}
$latte->render('mail.latte', new MailTemplateParameters(
lang: $this->lang,
subject: $title,
price: $this->getPrice(),
items: [],
address: $userAddress,
));
Değişkenin Otomatik Çıkmasını Devre Dışı Bırakma
Değişken bir HTML dizesi içeriyorsa, Latte'nin otomatik olarak (ve bu nedenle çift) kaçış yapmaması için onu
işaretleyebilirsiniz. Bu, şablonda |noescape
belirtme ihtiyacını ortadan kaldırır.
En kolay yol, dizeyi bir Latte\Runtime\Html
nesnesine sarmaktır:
$params = [
'articleBody' => new Latte\Runtime\Html($article->htmlBody),
];
Latte ayrıca Latte\HtmlStringable
arayüzünü uygulayan tüm nesnelerden kaçış yapmaz. Böylece,
__toString()
yöntemi otomatik olarak kaçılmayacak HTML kodu döndürecek olan kendi sınıfınızı
oluşturabilirsiniz:
class Emphasis extends Latte\HtmlStringable
{
public function __construct(
private string $str,
) {
}
public function __toString(): string
{
return '<em>' . htmlspecialchars($this->str) . '</em>';
}
}
$params = [
'foo' => new Emphasis('hello'),
];
__toString
yöntemi doğru HTML döndürmeli ve parametre kaçışını sağlamalıdır, aksi
takdirde bir XSS güvenlik açığı oluşabilir!
Latte Filtreler, Etiketler vb. ile Nasıl Genişletilir?
Latte'ye özel bir filtre, fonksiyon, etiket vb. nasıl eklenir? Latte'yi genişletme bölümünde bulabilirsiniz. Yaptığınız değişiklikleri farklı projelerde yeniden kullanmak veya başkalarıyla paylaşmak istiyorsanız, bir uzantı oluşturmalısınız.
Şablondaki Herhangi Bir Kod {php ...}
İçerisine sadece PHP ifadeleri yazılabilir. {do}
etiketini
kullanamazsınız, bu nedenle örneğin if ... else
gibi yapılar veya noktalı virgülle sonlandırılmış ifadeler
ekleyemezsiniz.
Ancak, {php ...}
etiketini ekleyen RawPhpExtension
uzantısını kaydedebilirsiniz. Bunu herhangi bir
PHP kodu eklemek için kullanabilirsiniz. Herhangi bir sandbox modu kuralına tabi değildir, bu nedenle kullanım şablon
yazarının sorumluluğundadır.
$latte->addExtension(new Latte\Essential\RawPhpExtension);
Oluşturulan Kodun Kontrol Edilmesi
Latte şablonları PHP koduna derler. Elbette, oluşturulan kodun sözdizimsel olarak geçerli olmasını sağlar. Ancak, üçüncü parti eklentiler veya RawPhpExtension kullanıldığında, Latte oluşturulan dosyanın doğruluğunu garanti edemez. Ayrıca, PHP'de sözdizimsel olarak doğru olan ancak yasak olan (örneğin, $this değişkenine bir değer atamak) ve PHP Derleme Hatasına neden olan bir kod yazabilirsiniz. Böyle bir işlemi bir şablona yazarsanız, oluşturulan PHP koduna da dahil edilecektir. PHP'de iki yüzden fazla farklı yasaklı işlem olduğundan, Latte bunları tespit etmeyi amaçlamaz. PHP'nin kendisi bunları oluşturma sırasında işaretleyecektir ve bu genellikle bir sorun teşkil etmez.
Ancak, şablon derlemesi sırasında PHP Derleme Hatası içermediğini bilmek istediğiniz durumlar vardır. Özellikle şablonlar kullanıcılar tarafından düzenlenebiliyorsa veya Sandbox kullanıyorsanız. Böyle bir durumda, derleme sırasında şablonları kontrol ettirin. Bu işlevi Engine::enablePhpLint() yöntemini kullanarak etkinleştirebilirsiniz. Kontrol için PHP ikilisini çağırması gerektiğinden, yolunu bir parametre olarak geçirin:
$latte = new Latte\Engine;
$latte->enablePhpLinter('/path/to/php');
try {
$latte->compile('home.latte');
} catch (Latte\CompileException $e) {
// PHP'de Latte hatalarını ve ayrıca Derleme Hatasını yakalar
echo 'Error: ' . $e->getMessage();
}
Yerel
Latte, sayıların, tarihlerin ve sıralamanın biçimlendirilmesini etkileyen yerel ayarı ayarlamanıza olanak tanır.
setLocale()
yöntemi kullanılarak ayarlanır. Yerel ayar tanımlayıcısı, PHP intl
uzantısını
kullanan IETF dil etiketi standardını izler. Bir dil kodu ve muhtemelen bir ülke kodundan oluşur, örneğin, ABD'deki
İngilizce için en_US
, Almanya'daki Almanca için de_DE
vb.
$latte = new Latte\Engine;
$latte->setLocale('cs');
Yerel ayar, localDate, sort, number ve bytes filtrelerini etkiler.
PHP intl
eklentisini gerektirir. Latte'deki ayar PHP'deki global yerel ayarını etkilemez.
Sıkı Mod
Sıkı ayrıştırma modunda, Latte eksik kapanış HTML etiketlerini kontrol eder ve ayrıca $this
değişkeninin
kullanımını devre dışı bırakır. Bunu açmak için:
$latte = new Latte\Engine;
$latte->setStrictParsing();
declare(strict_types=1)
başlığıyla şablon oluşturmak için aşağıdakileri yapın:
$latte = new Latte\Engine;
$latte->setStrictTypes();
Şablonlarda Çeviri
Eklemek için TranslatorExtension
uzantısını kullanın {_...}
, {translate}
ve filtre translate
şablona eklenir. Şablonun değerlerini veya
bölümlerini diğer dillere çevirmek için kullanılırlar. Değiştirge, çeviriyi gerçekleştiren yöntemdir (PHP
çağrılabiliri):
class MyTranslator
{
public function __construct(private string $lang)
{}
public function translate(string $original): string
{
// $this->lang'a göre $original'den $translated oluşturun
return $translated;
}
}
$translator = new MyTranslator($lang);
$extension = new Latte\Essential\TranslatorExtension(
$translator->translate(...), // PHP 8.0'da [$translator, 'translate']
);
$latte->addExtension($extension);
Çevirmen, şablon işlendiğinde çalışma zamanında çağrılır. Ancak Latte, şablon derlemesi sırasında tüm statik metinleri çevirebilir. Bu performans tasarrufu sağlar çünkü her dize yalnızca bir kez çevrilir ve sonuçta ortaya çıkan çeviri derlenmiş dosyaya yazılır. Bu, önbellek dizininde şablonun her dil için bir tane olmak üzere birden fazla derlenmiş sürümünü oluşturur. Bunu yapmak için sadece ikinci parametre olarak dili belirtmeniz gerekir:
$extension = new Latte\Essential\TranslatorExtension(
$translator->translate(...),
$lang,
);
Statik metin ile örneğin {_'hello'}
veya {translate}hello{/translate}
kastedilmektedir.
{_$foo}
gibi statik olmayan metinler çalışma zamanında çevrilmeye devam edecektir.
Şablon, $params
dizisi olarak aldığı {_$original, foo: bar}
veya
{translate foo: bar}
aracılığıyla çevirmene ek parametreler de iletebilir:
public function translate(string $original, ...$params): string
{
// $params['foo'] === 'bar'
}
Hata Ayıklama ve Tracy
Latte, geliştirmeyi mümkün olduğunca keyifli hale getirmeye çalışır. Hata ayıklama amacıyla, üç etiket vardır {dump}
, {debugbreak}
ve {trace}
.
Harika hata ayıklama aracı Tracy 'yi yüklerseniz ve Latte eklentisini etkinleştirirseniz en fazla konforu elde edersiniz:
// Tracy'nin
Tracy\Debugger::enable();
$latte = new Latte\Engine;
// Tracy'nin uzantısını etkinleştirir
$latte->addExtension(new Latte\Bridges\Tracy\TracyExtension);
Artık satır ve sütun vurgulamalı şablonlardaki hatalar da dahil olmak üzere tüm hataları düzgün bir kırmızı ekranda göreceksiniz(video). Aynı zamanda, Tracy Bar olarak adlandırılan sağ alt köşede, tüm işlenmiş şablonları ve ilişkilerini (şablona veya derlenmiş koda tıklama imkanı dahil) ve değişkenleri açıkça görebileceğiniz Latte için bir sekme görünür:
Latte şablonları okunabilir PHP koduna derlediğinden, IDE'nizde rahatça adım atabilirsiniz.
Linter: Şablon Sözdizimini Doğrulama
Linter aracı tüm şablonları gözden geçirmenize ve sözdizimi hatalarını kontrol etmenize yardımcı olacaktır. Konsoldan başlatılır:
vendor/bin/latte-lint <path>
Sıkı modu etkinleştirmek için --strict
parametresini kullanın.
Özel etiketler kullanıyorsanız, özelleştirilmiş Linter'ınızı da oluşturun, örneğin
custom-latte-lint
:
#!/usr/bin/env php
<?php
// autoload.php dosyasının gerçek yolunu girin
require __DIR__ . '/vendor/autoload.php';
$path = $argv[1] ?? '.';
$linter = new Latte\Tools\Linter;
$latte = $linter->getEngine();
// bireysel uzantılarınızı buraya ekleyin
$latte->addExtension(/* ... */);
$ok = $linter->scanDirectory($path);
exit($ok ? 0 : 1);
Alternatif olarak, kendi Latte\Engine
nesnenizi Linter'a aktarabilirsiniz:
$latte = new Latte\Engine;
// burada $latte nesnesini yapılandırıyoruz
$linter = new Latte\Tools\Linter(engine: $latte);
Dizeden Şablon Yükleme
Belki de test amacıyla şablonları dosyalar yerine dizelerden yüklemeniz mi gerekiyor? StringLoader size yardımcı olacaktır:
$latte->setLoader(new Latte\Loaders\StringLoader([
'main.file' => '{include other.file}',
'other.file' => '{if true} {$var} {/if}',
]));
$latte->render('main.file', $params);
İstisna İşleyici
Beklenen istisnalar için kendi işleyicinizi tanımlayabilirsiniz. İçinde yükseltilen istisnalar {try}
ve sandbox
'ta ona aktarılır.
$loggingHandler = function (Throwable $e, Latte\Runtime\Template $template) use ($logger) {
$logger->log($e);
};
$latte = new Latte\Engine;
$latte->setExceptionHandler($loggingHandler);
Otomatik Yerleşim Arama
Etiketi kullanma {layout}
'de,
şablon kendi üst şablonunu belirler. Düzenin otomatik olarak aranmasını sağlamak da mümkündür, bu da
{layout}
etiketini içermeleri gerekmeyeceğinden şablon yazmayı basitleştirecektir.
Bu, aşağıdaki şekilde gerçekleştirilir:
$finder = function (Latte\Runtime\Template $template) {
if (!$template->getReferenceType()) {
// üst şablon dosyasının yolunu döndürür
return 'automatic.layout.latte';
}
};
$latte = new Latte\Engine;
$latte->addProvider('coreParentFinder', $finder);
Şablonun bir düzene sahip olmaması gerekiyorsa, bunu {layout none}
etiketiyle belirtecektir.