Yii - Widget'lar
Widget, HTML, CSS ve JS içeren yeniden kullanılabilir bir istemci tarafı kodudur. Bu kod, minimum mantık içerir ve biryii\base\Widgetnesne. Bu nesneyi herhangi bir görünüme kolayca ekleyebilir ve uygulayabiliriz.
Step 1 - Widget'ları çalışırken görmek için bir actionTestWidget işlevi SiteController aşağıdaki kod ile.
public function actionTestWidget() {
return $this->render('testwidget');
}
Yukarıdaki örnekte, sadece bir View aranan “testwidget”.
Step 2 - Şimdi, views / site klasörünün içinde adlı bir View dosyası oluşturun. testwidget.php.
<?php
use yii\bootstrap\Progress;
?>
<?= Progress::widget(['percent' => 60, 'label' => 'Progress 60%']) ?>
Step 3 - Eğer gidersen http://localhost:8080/index.php?r=site/test-widget, ilerleme çubuğu widget'ını göreceksiniz.
Widget'ları Kullanma
Bir pencere öğesini bir View, aramalısın yii\base\Widget::widget()işlevi. Bu işlev, parçacığı başlatmak için bir yapılandırma dizisi alır. Önceki örnekte, yapılandırma nesnesinin yüzde ve etiketli parametrelerini içeren bir ilerleme çubuğu ekledik.
Bazı widget'lar bir blok içerik alır. Arasına kapatılmalıdıryii\base\Widget::begin() ve yii\base\Widget::end()fonksiyonlar. Örneğin, aşağıdaki pencere öğesi bir iletişim formu görüntüler -
<?php $form = ActiveForm::begin(['id' => 'contact-form']); ?>
<?= $form->field($model, 'name') ?>
<?= $form->field($model, 'email') ?>
<?= $form->field($model, 'subject') ?>
<?= $form->field($model, 'body')->textArea(['rows' => 6]) ?>
<?= $form->field($model, 'verifyCode')->widget(Captcha::className(), [
'template' =>
'<div class="row">
<div class = "col-lg-3">{image}</div>
<div class = "col-lg-6">{input}</div>
</div>',
]) ?>
<div class = "form-group">
<?= Html::submitButton('Submit', ['class' => 'btn btn-primary',
'name' => 'contact-button']) ?>
</div>
<?php ActiveForm::end(); ?>
Widget Oluşturma
Bir widget oluşturmak için, yii\base\Widget. O zaman geçersiz kılmalısınyii\base\Widget::init() ve yii\base\Widget::run()fonksiyonlar. run()işlevi, oluşturma sonucunu döndürmelidir. init() işlevi, pencere öğesi özelliklerini normalleştirmelidir.
Step 1- Proje kökünde bir bileşenler klasörü oluşturun. Bu klasörün içinde adlı bir dosya oluşturun.FirstWidget.php aşağıdaki kod ile.
<?php
namespace app\components;
use yii\base\Widget;
class FirstWidget extends Widget {
public $mes; public function init() { parent::init(); if ($this->mes === null) {
$this->mes = 'First Widget'; } } public function run() { return "<h1>$this->mes</h1>";
}
}
?>
Step 2 - Modify testwidget aşağıdaki şekilde görüntüleyin.
<?php
use app\components\FirstWidget;
?>
<?= FirstWidget∷widget() ?>
Step 3 - Git http://localhost:8080/index.php?r=site/test-widget. Aşağıdakileri göreceksiniz.
Step 4 - İçeriği arasına almak için begin() ve end() aramalar, değiştirmelisiniz FirstWidget.php dosya.
<?php
namespace app\components;
use yii\base\Widget;
class FirstWidget extends Widget {
public function init() {
parent::init();
ob_start();
}
public function run() {
$content = ob_get_clean(); return "<h1>$content</h1>";
}
}
?>
Step 5- Şimdi h1 etiketleri tüm içeriği çevreleyecektir. Kullandığımıza dikkat edinob_start()çıktıyı tamponlama işlevi. Testwidget görünümünü aşağıdaki kodda verildiği gibi değiştirin.
<?php
use app\components\FirstWidget;
?>
<?php FirstWidget::begin(); ?>
First Widget in H1
<?php FirstWidget::end(); ?>
Aşağıdaki çıktıyı göreceksiniz -
Önemli noktalar
Widget'lar -
MVC modeline göre oluşturulmalıdır. Sunum katmanlarını görünümlerde ve mantıkta widget sınıflarında tutmalısınız.
Bağımsız olarak tasarlanın. Son geliştirici bunu bir Görünüm olarak tasarlayabilmelidir.