Flex - Penanganan Acara

Flex menggunakan konsep event untuk meneruskan data dari satu objek ke objek lain tergantung pada keadaan atau interaksi pengguna dalam aplikasi.

ActionScript memiliki file generik Eventkelas yang mendefinisikan banyak fungsionalitas yang dibutuhkan untuk bekerja dengan acara. Setiap kali sebuah event terjadi dalam aplikasi Flex, tiga tipe objek dari hierarki kelas Event dibuat.

Acara memiliki tiga properti utama berikut

Sr Tidak Deskripsi properti
1

Type

Itu typemenyatakan tentang peristiwa seperti apa yang baru saja terjadi. Ini bisa berupa klik, inisialisasi, gerakan mouse, ubah, dll. Nilai aktual akan diwakili oleh konstanta seperti MouseEvent.CLICK.

2

Target

Itu target properti Peristiwa adalah referensi objek ke komponen yang menghasilkan peristiwa. Jika Anda mengklik Tombol dengan id clickMeButton, target peristiwa klik itu adalah clickMeButton

3

CurrentTarget

Itu currentTargetproperti bervariasi dalam hierarki penampung. Ini terutama berkaitan dengan aliran peristiwa.

Tahapan Alur Peristiwa

Sebuah acara melewati tiga fase mencari penangan acara.

Sr Tidak Fase & Deskripsi
1

Capture

Pada tahap capture, program akan mulai mencari event handler dari luar (atau atas) induk sampai yang paling dalam. Fase penangkapan berhenti di induk objek yang memicu peristiwa tersebut.

2

Target

Dalam fase target, komponen yang memicu kejadian, diperiksa untuk penanganan kejadian.

3

Bubble

Fase Gelembung adalah kebalikan dari fase penangkapan, bekerja kembali melalui struktur, dari induk komponen target ke atas.

Pertimbangkan kode aplikasi berikut -

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx
   width = "100%" height = "100%" minWidth = "500" minHeight = "500" >
   
   <s:Panel>
      <s:Button id = "clickMeButton" label = "Click Me!" click = "doAction( );" />
   </s:Panel>   
</s:Application>

Ketika pengguna mengklik Tombol, dia juga mengklik Panel dan Aplikasi.

Acara ini melewati tiga fase untuk mencari tugas penangan acara.

Mari kita ikuti langkah-langkah di bawah ini untuk menguji penyerahan acara dalam aplikasi Flex -

Langkah Deskripsi
1 Buat proyek dengan nama HelloWorld di bawah paket com.tutorialspoint.client seperti yang dijelaskan di bab Flex - Buat Aplikasi .
2 Ubah HelloWorld.mxml seperti yang dijelaskan di bawah ini. Jaga sisa file tidak berubah.
3 Kompilasi dan jalankan aplikasi untuk memastikan logika bisnis berfungsi sesuai kebutuhan.

Berikut adalah konten file mxml yang dimodifikasi src/com.tutorialspoint/HelloWorld.mxml.

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009"
   xmlns:s = "library://ns.adobe.com/flex/spark"
   xmlns:mx = "library://ns.adobe.com/flex/mx
   width = "100%" height = "100%" minWidth = "500" minHeight = "500">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         protected function reportEvent(event:MouseEvent):void {
            var target:String = event.target.id;
            var currentTarget:String = event.target.id;
            var eventPhase: String;

            if(event.target is Button) {
               var button:Button = event.target as Button;
               target = button.label + " Button";
            } else if(event.target is HGroup) {
               var hGroup:HGroup = event.target as HGroup;
               target = hGroup.id + " HGroup";
            } else if(event.target is Panel) {
               var panel:Panel = event.target as Panel;
               target = panel.id + " Panel";
            }

            if(event.currentTarget is Button) {
               var button1:Button = event.currentTarget as Button;
               currentTarget = button1.label + " Button";
            } else if(event.currentTarget is HGroup) {
               var hGroup1:HGroup = event.currentTarget as HGroup;
               currentTarget = hGroup1.id + " HGroup";
            } else if(event.currentTarget is Panel) {
               var panel1:Panel = event.currentTarget as Panel;
               currentTarget = panel1.id + " Panel";
            }

            var eventPhaseInt:uint = event.eventPhase;

            if(eventPhaseInt == EventPhase.AT_TARGET) {
               eventPhase = "Target";
            } else if(eventPhaseInt == EventPhase.BUBBLING_PHASE) {
               eventPhase = "Bubbling";
            } else if(eventPhaseInt == EventPhase.CAPTURING_PHASE) {
               eventPhase = "Capturing";
            }
            
            reports.text += " Target: " + target + "\n currentTarget: " +
               currentTarget + "\n Phase: " + eventPhase + "\n----------\n";
         }
      ]]>
   </fx:Script>
   
   <s:BorderContainer width = "630" height = "480" id = "mainContainer"
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "10"
         horizontalAlign = "center" verticalAlign = "middle">
         <s:Label id = "lblHeader" text = "Event Handling Demonstration"
            fontSize = "40" color = "0x777777" styleName = "heading" />

         <s:Panel id = "parentPanel" title = "Main Parent"
            click = "reportEvent(event)" width = "500"
            height = "100" includeInLayout = "true" visible = "true">
            <s:layout>
               <s:VerticalLayout  gap = "10" verticalAlign = "middle"
                  horizontalAlign = "center" />
            </s:layout>
            
            <s:HGroup id = "mainHGroup" click = "reportEvent(event)">
               <s:Button label = "Click Me" click = "reportEvent(event)" />
            </s:HGroup>
         </s:Panel>

         <s:Panel id = "reportPanel" title = "Events" width = "500" height = "230">
            <mx:Text id = "reports" />
         </s:Panel>
      </s:VGroup>
   </s:BorderContainer>
</s:Application>

Setelah Anda siap dengan semua perubahan yang dilakukan, mari kita kompilasi dan jalankan aplikasi dalam mode normal seperti yang kita lakukan di bab Flex - Membuat Aplikasi . Jika semuanya baik-baik saja dengan aplikasi Anda, itu akan menghasilkan hasil sebagai berikut: [ Coba online ]