FuelPHP - Etkinlikler

Bir eventprogram tarafından tanınan ve programın kendisi tarafından işlenebilen bir eylem veya oluşumdur. Örneğin, my_fuel_event adında bir eylem veya olay tanımlayabilir ve ardından olay, my_fuel_event çağrıldığında bazı işler yapabiliriz. FuelPHP sınıf sağlar,Event uygulamadaki olaylarla çalışmak.

Sistem Olayları

FuelPHP, uygulama tarafından tanımlanan olaylar çağrıldığında veya çalıştırıldığında bazı işler yapabileceğimiz bazı olayları tanımladı. Bu yardım, FuelPHP'nin çekirdek kod dosyalarını değiştirmeden FuelPHP'nin davranışını değiştiriyor. Önceden tanımlanmış olaylar aşağıdaki gibidir -

  • app_created - Bu olay, FuelPHP çerçevesi başlatıldıktan sonra tetiklenecektir.

  • request_created - Bu olay, yeni bir İstek nesnesi taklit edildikten sonra tetiklenecektir.

  • request_started - Bu olay, bir talebin yerine getirilmesi istendiğinde tetiklenecektir.

  • controller_started - Bu olay, denetleyiciler () yöntemi çağrılmadan önce tetiklenecektir.

  • controller_finished - Bu olay, denetleyiciler () yöntemi çağrıldıktan ve yanıt alındıktan sonra tetiklenecektir.

  • response_created - Bu olay, yeni bir Response nesnesi oluşturulduktan sonra tetiklenecektir.

  • request_finished - Bu olay, bir İsteğin yürütülmesi tamamlandığında ve bir yanıt alındığında tetiklenecektir.

  • shutdown - Bu olay, ana istek işlendikten ve çıktı gönderildikten sonra tetiklenecektir.

Olayları özel konfigürasyon dosyasında halledebiliriz, fuel/app/config/events.php aşağıdaki gibi -

<?php  
   return array ( 
      'fuelphp' => array ( 
         'app_created' => function() { 
            // After FuelPHP initialised
         }, 
         'request_created' => function() { 
            // After Request forged 
         }, 
         'request_started' => function() { 
            // Request is requested 
         }, 
         'controller_started' => function() { 
            // Before controllers before() method called 
         }, 
         'controller_finished' => function() { 
            // After controllers after() method called 
         }, 
         'response_created' => function() { 
            // After Response forged 
         }, 
         'request_finished' => function() { 
            // Request is complete and Response received 
         }, 
         'shutdown' => function() { 
            // Output has been send out 
         }, 
      ), 
   );

Etkinlik Yöntemleri

Event sınıfı, olayları kaydetmek, kaydını silmek ve ateşlemek için yöntemler sağlar. Bunlar aşağıdaki gibidir,

Kayıt ol()

Kayıt yöntemi, dosyaların tetikleme yöntemi çağrıldığında çalıştırılacak bir nesneyi kaydetmesine izin verir.

$my_event_code = function() { 
   echo 'my event'; 
} 
Event::register('my_event', $my_event_code);

kaydı iptal et ()

Kayıt silme yöntemi, dosyaların tetikleme yöntemi çağrıldığında çalıştırılacak bir nesnenin kaydını silmesine izin verir.

Event::unregister('my_event', $my_event_code);

tetik ()

Tetikleme yöntemi, kayıt yöntemi aracılığıyla ilişkilendirilen geri aramaları tetiklemek veya etkinleştirmek için kullanılır.

Event::trigger('my_event');

has_events ()

Has_events yöntemi mevcuttur, böylece belirli bir kayıtlı olayın tetikleyicilere sahip olup olmadığını kontrol edebilirsiniz.

Event::has_events('my_event');

forge ()

Forge, yeni bir olay nesnesi döndürür.

$event = Event::forge();

örnek ()

Örnek, tekli yeni bir olay nesnesi döndürür.

$event = Event::instance('event_instance');