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.