लारवेल - इवेंट हैंडलिंग

ईवेंट एक सरल पर्यवेक्षक कार्यान्वयन प्रदान करते हैं जो उपयोगकर्ता को वेब एप्लिकेशन में ट्रिगर की गई विभिन्न घटनाओं की सदस्यता लेने और सुनने की अनुमति देता है। लारवेल में सभी घटना वर्गों में संग्रहीत हैंapp/Events फ़ोल्डर और श्रोताओं में संग्रहीत हैं app/Listeners फ़ोल्डर।

आपके वेब एप्लिकेशन में घटनाओं और श्रोताओं को उत्पन्न करने के लिए कारीगर कमांड नीचे दिखाया गया है -

php artisan event:generate

यह कमांड ऊपर चर्चा की गई घटनाओं और श्रोताओं को संबंधित फ़ोल्डर में उत्पन्न करता है।

ईवेंट और श्रोता वेब एप्लिकेशन को डिकोड करने का एक शानदार तरीका प्रदान करते हैं, क्योंकि एक इवेंट में कई श्रोता हो सकते हैं जो एक-दूसरे से स्वतंत्र हों। कारीगर कमांड द्वारा बनाए गए इवेंट फ़ोल्डर में निम्न दो फाइलें शामिल हैं: event.php और SomeEvent.php। उन्हें यहाँ दिखाया गया है -

Event.php

<?php
namespace App\Events;
abstract class Event{
   //
}

जैसा कि ऊपर उल्लेख किया गया है, event.php इसमें कक्षा की मूल परिभाषा शामिल है Event और नाम स्थान के लिए कॉल करता है App\Events। कृपया ध्यान दें कि इस फ़ाइल में उपयोगकर्ता परिभाषित या कस्टम ईवेंट बनाए गए हैं।

SomeEvent.php

<?php

namespace App\Events;

use App\Events\Event;
use Illuminate\Queue\SerializesModels;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;

class SomeEvent extends Event{
   use SerializesModels;
   /**
      * Create a new event instance.
      *
      * @return void
   */
   
   public function __construct() {
      //
   }
   
   /**
      * Get the channels the event should be broadcast on.
      *
      * @return array
   */
   
   public function broadcastOn() {
      return [];
   }
}

ध्यान रखें कि यह फ़ाइल वेब अनुप्रयोग में घटनाओं के प्रसारण के लिए क्रमांकन का उपयोग करती है और इस फ़ाइल में आवश्यक पैरामीटर भी आरंभ किए जाते हैं।

उदाहरण के लिए, अगर हमें किसी घटना को दर्ज करने के लिए कंस्ट्रक्टर में ऑर्डर वैरिएबल को इनिशियलाइज़ करना है, तो हम इसे निम्न तरीके से कर सकते हैं -

public function __construct(Order $order) {
   $this->order = $order;
}

श्रोताओं

श्रोता पंजीकृत होने वाली घटना में बताई गई सभी गतिविधियों को संभालते हैं। कारीगर की आज्ञाevent:generate सभी बनाता है listeners में app/listenersनिर्देशिका। श्रोता फ़ोल्डर में एक फ़ाइल शामिल हैEventListener.php जिसमें श्रोताओं को संभालने के लिए आवश्यक सभी तरीके हैं।

EventListener.php

<?php

namespace App\Listeners;

use App\Events\SomeEvent;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;

class EventListener{
   /**
      * Create the event listener.
      *
      * @return void
   */
   
   public function __construct() {
      //
   }

   /**
      * Handle the event.
      *
      * @param SomeEvent $event
      * @return void
   */
   
   public function handle(SomeEvent $event) {
      //
   }
}

जैसा कि कोड में बताया गया है, इसमें शामिल है handleविभिन्न घटनाओं के प्रबंधन के लिए कार्य करते हैं। हम विभिन्न स्वतंत्र श्रोताओं को बना सकते हैं जो किसी एक घटना को लक्षित करते हैं।