Ext.js - Panduan Cepat

Ext JS adalah kerangka kerja JavaScript populer yang menyediakan UI kaya untuk membangun aplikasi web dengan fungsionalitas lintas-browser. Ext JS pada dasarnya digunakan untuk membuat aplikasi desktop. Mendukung semua browser modern seperti IE6 +, FF, Chrome, Safari 6+, Opera 12+, dll. Sedangkan produk lain dari Sencha, Sencha Touch digunakan untuk aplikasi mobile.

Ext JS didasarkan pada arsitektur MVC / MVVM. Versi terbaru dari Ext JS 6 adalah platform tunggal, yang dapat digunakan untuk aplikasi desktop dan seluler tanpa kode yang berbeda untuk platform yang berbeda.

Sejarah

Ext JS 1.1

Versi pertama Ext JS dikembangkan oleh Jack Slocum pada tahun 2006. Ini adalah sekumpulan kelas utilitas, yang merupakan perpanjangan dari YUI. Dia menamai perpustakaan itu sebagai YUI-ext.

Ext JS 2.0

Ext JS versi 2.0 dirilis pada tahun 2007. Versi ini memiliki dokumentasi API baru untuk aplikasi desktop dengan fitur terbatas. Versi ini tidak memiliki kompatibilitas mundur dengan versi Ext JS sebelumnya.

Ext JS 3.0

Ext JS versi 3.0 dirilis pada tahun 2009. Versi ini menambahkan fitur baru sebagai tampilan grafik dan daftar tetapi dengan mengorbankan kecepatan. Ini memiliki kompatibilitas mundur dengan versi 2.0.

Ext JS 4.0

Setelah rilis Ext JS 3, pengembang Ext JS memiliki tantangan besar untuk meningkatkan kecepatan. Ext JS versi 4.0 dirilis pada tahun 2011. Struktur lengkapnya telah direvisi, yang diikuti oleh arsitektur MVC dan aplikasi yang cepat.

Ext JS 5.0

Ext JS versi 5.0 dirilis pada tahun 2014. Perubahan besar dalam rilis ini adalah mengubah arsitektur MVC menjadi arsitektur MVVM. Ini mencakup kemampuan untuk membangun aplikasi desktop pada perangkat yang mendukung sentuhan, pengikatan data dua arah, tata letak responsif, dan banyak lagi fitur lainnya.

Ext JS 6.0

Ext JS 6 menggabungkan kerangka kerja Ext JS (untuk aplikasi desktop) dan Sencha Touch (untuk aplikasi seluler).

fitur

Berikut adalah fitur yang disorot dari Ext JS.

  • Widget UI yang dapat disesuaikan dengan koleksi UI yang kaya seperti kisi, kisi pivot, formulir, bagan, pohon.

  • Kompatibilitas kode versi baru dengan yang lebih lama.

  • Manajer tata letak yang fleksibel membantu mengatur tampilan data dan konten di berbagai browser, perangkat, dan ukuran layar.

  • Paket data lanjutan memisahkan widget UI dari lapisan data. Paket data memungkinkan pengumpulan data sisi klien menggunakan model yang sangat fungsional yang memungkinkan fitur seperti pengurutan dan pemfilteran.

  • Ini adalah protokol agnostik, dan dapat mengakses data dari sumber back-end mana pun.

  • Widget Ext JS Tema yang Dapat Disesuaikan tersedia dalam beberapa tema out-of-the-box yang konsisten di seluruh platform.

Manfaat

Sencha Ext JS adalah standar terdepan untuk pengembangan aplikasi web tingkat bisnis. Ext JS menyediakan alat yang diperlukan untuk membangun aplikasi yang kuat untuk desktop dan tablet.

  • Merampingkan pengembangan lintas platform di seluruh desktop, tablet, dan smartphone - untuk browser modern dan lama.

  • Meningkatkan produktivitas tim pengembangan dengan mengintegrasikan ke dalam lingkungan pengembangan perusahaan melalui plugin IDE.

  • Mengurangi biaya pengembangan aplikasi web.

  • Memberdayakan tim untuk membuat aplikasi dengan pengalaman pengguna yang menarik.

  • Menawarkan sekumpulan widget untuk membuat UI yang kuat dengan mudah.

  • Mengikuti arsitektur MVC, maka kodenya sangat mudah dibaca.

Batasan

  • Ukuran pustaka yang besar, sekitar 500 KB, yang membuat waktu pemuatan awal lebih lama dan membuat aplikasi menjadi lambat.

  • HTML penuh dengan tag yang membuatnya rumit dan sulit untuk di-debug.

  • Menurut kebijakan lisensi publik umum, ini gratis untuk aplikasi open source tetapi berbayar untuk aplikasi komersial.

  • Terkadang untuk memuat bahkan hal-hal sederhana memerlukan beberapa baris pengkodean, yang lebih sederhana dalam html atau JQuery biasa.

  • Membutuhkan developer yang cukup berpengalaman untuk mengembangkan aplikasi Ext JS.

Alat

Berikut ini adalah alat yang disediakan oleh Sencha yang digunakan untuk pengembangan aplikasi Ext JS terutama di tingkat produksi.

Sencha CMD

Sencha CMD adalah alat yang menyediakan fitur minifikasi kode JS Ext, perancah, dan pembuatan pembuatan produksi.

Plugin Sencha IDE

Plugin Sencha IDE mengintegrasikan kerangka kerja Sencha ke dalam IntelliJ, WebStorm IDEs, yang membantu meningkatkan produktivitas pengembang dengan menyediakan fitur-fitur seperti penyelesaian kode, inspeksi kode, navigasi kode, pembuatan kode, pemfaktoran ulang kode, pembuatan templat, pemeriksaan ejaan, dll.

Inspektur Sencha

Sencha Inspector adalah alat debugging yang membantu debugger untuk men-debug masalah apa pun saat pengembangan.

Pengaturan Lingkungan Lokal

Bagian ini memandu Anda tentang cara mengunduh dan menyiapkan Ext JS di komputer Anda. Harap ikuti langkah-langkah untuk menyiapkan lingkungan.

Mendownload File Perpustakaan

Unduh versi percobaan file pustaka Ext JS dari Sencha https://www.sencha.com. Anda akan mendapatkan versi percobaan dari situs ini pada id email terdaftar Anda, yang akan berupa folder zip bernama ext-6.0.1-trial.

Buka zip folder dan Anda akan menemukan berbagai file JavaScript dan CSS, yang akan Anda masukkan ke dalam aplikasi kami. Kami sebagian besar akan menyertakan file-file berikut -

JavaScript Files - File JS yang dapat Anda temukan di bawah folder \ ext-6.0.1-trial \ ext6.0.1 \ build adalah -

Sr Tidak Deskripsi berkas
1

ext.js

Ini adalah file inti yang berisi semua fungsi untuk menjalankan aplikasi.

2

ext-all.js

File ini berisi semua kode yang diperkecil tanpa komentar di dalam file.

3

ext-all-debug.js

Ini adalah versi ext-all.js yang tidak diminimalkan untuk tujuan debugging.

4

ext-all-dev.js

File ini juga tidak diminimalkan dan digunakan untuk tujuan pengembangan karena berisi semua komentar dan log konsol untuk memeriksa kesalahan / masalah apa pun.

5

ext-all.js

File ini digunakan untuk tujuan produksi karena ukurannya jauh lebih kecil daripada yang lain.

Anda dapat menambahkan file-file ini ke folder JS proyek Anda atau Anda dapat memberikan jalur langsung tempat file tersebut berada di sistem Anda.

CSS Files - Ada sejumlah file berbasis tema, yang dapat Anda temukan di folder \ ext6.0.1-trial \ ext-6.0.1 \ build \ classic \ theme-classic \ resources \ theme-classic-all.css

  • Jika Anda akan menggunakan aplikasi desktop, maka Anda dapat menggunakan tema klasik di bawah folder \ ext-6.0.1-trial \ ext-6.0.1 \ build \ classic

  • Jika kita akan menggunakan aplikasi seluler, maka Anda dapat menggunakan tema modern yang dapat ditemukan di folder \ ext-6.0.1-trial \ ext-6.0.1 \ build \ modern

File perpustakaan berikut akan ditambahkan dalam aplikasi Ext JS.

<html>
   <head>
      <link rel = "stylesheet" type = "text/css" 
         href = "..\ext-6.0.1-trial\ext-6.0.1\build\classic\theme-classic\resources\theme-classic-all.css" />
      <script type = "text/javascript" 
         src = "..\ext-6.0.1-trial\ext-6.0.1\build\ext-all.js" > </script>
      <script type = "text/javascript" src = "app.js" > </script>
   </head>
</html>

Anda akan menyimpan kode aplikasi ExtJS di file app.js.

Pengaturan CDN

CDN adalah jaringan pengiriman konten yang Anda tidak perlu mengunduh file pustaka Ext JS, sebagai gantinya Anda dapat langsung menambahkan tautan CDN untuk ExtJS ke program Anda sebagai berikut -

<html>
   <head>
      <link rel = "stylesheet" type = "text/css" 
         href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-crisp/resources/theme-crisp-all.css" / >
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"> </script>
      <script type = "text/javascript" src = "app.js" > </script> 
   </head>
</html>

Editor Populer

Karena ini adalah kerangka kerja JavaScript, yang digunakan untuk mengembangkan aplikasi web, dalam proyek kami, kami akan memiliki file HTML, JS. Untuk menulis program Ext JS kita, kita membutuhkan editor teks. Bahkan ada beberapa IDE yang tersedia di pasaran. Tetapi untuk saat ini, kita dapat mempertimbangkan salah satu dari yang berikut -

  • Notepad - Pada mesin Windows, Anda dapat menggunakan editor teks sederhana seperti Notepad (Disarankan untuk tutorial ini), Notepad ++, sublim.

  • Eclipse - Ini adalah IDE yang dikembangkan oleh komunitas open-source eclipse dan dapat diunduh dari https://www.eclipse.org/.

Browser

Ext JS mendukung kompatibilitas lintas-browser, mendukung semua browser utama seperti -

  • IE 6 ke atas
  • Firefox 3.6 dan yang lebih baru
  • Chrome10 ke atas
  • Safari 4 ke atas
  • Opera 11 ke atas

Anda dapat menggunakan browser apa saja untuk menjalankan aplikasi Ext JS.

Konvensi penamaan adalah seperangkat aturan yang harus diikuti untuk pengidentifikasi. Itu membuat kode lebih mudah dibaca dan dimengerti oleh programmer lain juga.

Konvensi penamaan di Ext JS mengikuti konvensi JavaScript standar, yang tidak wajib tetapi merupakan praktik yang baik untuk diikuti. Ini harus mengikuti sintaks kasus unta untuk menamai kelas, metode, variabel dan properti.

Jika nama digabungkan dengan dua kata, kata kedua akan selalu dimulai dengan huruf besar. Misalnya, doLayout (), StudentForm, firstName, dll.

Nama Konvensi
Nama kelas Ini harus dimulai dengan huruf besar, diikuti dengan huruf besar-kecil. Misalnya, StudentClass
Nama Metode Ini harus dimulai dengan huruf kecil, diikuti dengan huruf besar-kecil. Misalnya, doLayout ()
Nama Variabel Ini harus dimulai dengan huruf kecil, diikuti dengan huruf besar-kecil. Misalnya, firstName
Nama Konstan Ini harus dalam huruf besar saja. Misalnya, COUNT, MAX_VALUE
Nama properti Ini harus dimulai dengan huruf kecil, diikuti dengan huruf besar-kecil. Misalnya, enableColumnResize = true

Ext JS mengikuti arsitektur MVC / MVVM.

MVC - Arsitektur Model View Controller (versi 4)

MVVM - Model View Viewmodel (versi 5)

Arsitektur ini tidak wajib untuk program, namun, praktik terbaiknya adalah mengikuti struktur ini agar kode Anda dapat dipelihara dan diatur dengan baik.

Struktur Proyek dengan Aplikasi Ext JS

----------src
----------resources
-------------------CSS files
-------------------Images
----------JavaScript
--------------------App Folder
-------------------------------Controller
------------------------------------Contoller.js
-------------------------------Model
------------------------------------Model.js
-------------------------------Store
------------------------------------Store.js
-------------------------------View
------------------------------------View.js
-------------------------------Utils
------------------------------------Utils.js
--------------------------------app.js
-----------HTML files

Folder aplikasi Ext JS akan berada di folder JavaScript proyek Anda.

Aplikasi akan berisi file controller, view, model, store, dan utility dengan app.js.

app.js- File utama dari mana aliran program akan dimulai, yang harus dimasukkan dalam file HTML utama menggunakan tag <script>. Aplikasi memanggil pengontrol aplikasi untuk fungsi lainnya.

Controller.js- Ini adalah file pengontrol arsitektur Ext JS MVC. Ini berisi semua kontrol aplikasi, event listener, dan sebagian besar fungsionalitas kode. Ini memiliki jalur yang ditentukan untuk semua file lain yang digunakan dalam aplikasi itu seperti store, view, model, require, mixins.

View.js- Berisi bagian antarmuka dari aplikasi, yang ditampilkan kepada pengguna. Ext JS menggunakan berbagai tampilan kaya UI, yang dapat diperluas dan disesuaikan di sini sesuai dengan kebutuhan.

Store.js- Ini berisi data yang di-cache secara lokal yang akan ditampilkan pada tampilan dengan bantuan objek model. Store mengambil data menggunakan proxy yang memiliki jalur yang ditentukan untuk layanan guna mengambil data backend.

Model.js- Berisi objek yang mengikat data penyimpanan untuk dilihat. Ini memiliki pemetaan objek data backend ke view dataIndex. Data diambil dengan bantuan toko.

Utils.js- Ini tidak termasuk dalam arsitektur MVC tetapi merupakan praktik terbaik untuk digunakan agar kode menjadi bersih, tidak rumit, dan lebih mudah dibaca. Kita dapat menulis metode dalam file ini dan memanggilnya di controller atau penyaji tampilan jika diperlukan. Ini juga berguna untuk tujuan penggunaan kembali kode.

Dalam arsitektur MVVM, pengontrol diganti dengan ViewModel.

ViewModel- Ini pada dasarnya menengahi perubahan antara tampilan dan model. Ini mengikat data dari model ke tampilan. Pada saat yang sama, tidak ada interaksi langsung dengan tampilan. Ia hanya memiliki pengetahuan tentang modelnya.

Bagaimana itu bekerja

Misalnya, jika kita menggunakan satu objek model di dua-tiga tempat di UI. Jika kita mengubah nilai di satu tempat UI, kita bisa melihat bahkan tanpa menyimpan perubahan itu. Nilai model berubah dan direfleksikan di semua tempat di UI, di mana pun model digunakan.

Itu membuat upaya pengembang jauh lebih sedikit dan lebih mudah karena tidak ada pengkodean tambahan yang diperlukan untuk mengikat data.

Bab ini mencantumkan langkah-langkah untuk menulis program Hello World pertama di Ext JS.

Langkah 1

Buat halaman index.htm di editor pilihan kami. Sertakan file perpustakaan yang diperlukan di bagian kepala halaman html sebagai berikut.

index.htm

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-classic/resources/theme-classic-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            Ext.create('Ext.Panel', {
               renderTo: 'helloWorldPanel',
               height: 200,
               width: 600,
               title: 'Hello world',
               html: 'First Ext JS Hello World Program'
            });
         });
      </script>
   </head>
   
   <body>
      <div id = "helloWorldPanel" />
   </body>
</html>

Penjelasan

  • Metode Ext.onReady () akan dipanggil setelah Ext JS siap untuk merender elemen Ext JS.

  • Metode ext.create () digunakan untuk membuat objek di Ext JS. Di sini kita membuat objek panel kelas Ext.Panel sederhana.

  • Ext.Panel adalah kelas standar di Ext JS untuk membuat panel.

  • Setiap kelas Ext JS memiliki properti yang berbeda untuk melakukan beberapa fungsi dasar.

Kelas Ext. Panel memiliki berbagai properti seperti -

  • renderToadalah elemen yang harus dirender panel ini. 'helloWorldPanel' adalah id div dalam file Index.html.

  • Height dan width properti untuk menyesuaikan ukuran panel.

  • Title properti adalah untuk memberikan judul ke panel.

  • Html properti adalah konten html yang akan ditampilkan di panel.

Langkah 2

Buka file index.htm di browser standar dan Anda akan mendapatkan output berikut di browser.

Ext JS adalah kerangka kerja JavaScript yang memiliki fungsi pemrograman berorientasi objek. Ext adalah namespace, yang merangkum semua kelas di Ext JS.

Mendefinisikan Kelas di Ext JS

Ext menyediakan lebih dari 300 class, yang dapat kita gunakan untuk berbagai fungsi.

Ext.define () digunakan untuk mendefinisikan kelas-kelas di Ext JS.

Sintaksis

Ext.define(class name, class members/properties, callback function);

Nama kelas adalah nama kelas menurut struktur aplikasi. Misalnya, appName.folderName.ClassName studentApp.view.StudentView.

Properti kelas / anggota mendefinisikan perilaku kelas.

Fungsi panggilan balik adalah opsional. Ini dipanggil ketika kelas telah dimuat dengan benar.

Contoh Definisi Kelas Ext JS

Ext.define(studentApp.view.StudentDeatilsGrid, {
   extend : 'Ext.grid.GridPanel',
   id : 'studentsDetailsGrid',
   store : 'StudentsDetailsGridStore',
   renderTo : 'studentsDetailsRenderDiv',
   layout : 'fit',
   
   columns : [{
      text : 'Student Name',
      dataIndex : 'studentName'
   },{
      text : 'ID',
      dataIndex : 'studentId'
   },{
      text : 'Department',
      dataIndex : 'department'
   }]
});

Membuat Objek

Seperti bahasa berbasis OOPS lainnya, kita juga dapat membuat objek di Ext JS.

Berikut adalah cara berbeda untuk membuat objek di Ext JS.

Menggunakan kata kunci baru

var studentObject = new student();
studentObject.getStudentName();

Menggunakan Ext.create ()

Ext.create('Ext.Panel', {
   renderTo : 'helloWorldPanel',
   height : 100,
   width : 100,
   title : 'Hello world',
   html : 	'First Ext JS Hello World Program'		
});

Warisan di Ext JS

Pewarisan adalah prinsip penggunaan fungsionalitas yang didefinisikan di kelas A ke dalam kelas B.

Di Ext JS, pewarisan dapat dilakukan menggunakan dua metode -

Ext.extend

Ext.define(studentApp.view.StudentDetailsGrid, {
   extend : 'Ext.grid.GridPanel',
   ...
});

Di sini, kelas kustom StudentDetailsGrid kami menggunakan fitur dasar kelas Ext JS GridPanel.

Menggunakan Mixins

Mixins adalah cara berbeda untuk menggunakan kelas A di kelas B tanpa perluasan.

mixins : {
   commons : 'DepartmentApp.utils.DepartmentUtils'
},

Mixin ditambahkan ke dalam pengontrol tempat kita mendeklarasikan semua kelas lain seperti store, view, dll. Dengan cara ini, kita dapat memanggil kelas DepartmentUtils dan menggunakan fungsinya di pengontrol atau dalam aplikasi ini.

Container di Ext JS adalah komponen dimana kita bisa menambahkan container lain atau komponen anak. Penampung ini dapat memiliki beberapa tata letak untuk mengatur komponen di dalam penampung. Kita dapat menambah atau menghapus komponen dari wadah dan dari elemen anaknya. Ext.container.Container adalah kelas dasar untuk semua kontainer di Ext JS.

Sr Tidak Deskripsi
1 Komponen di dalam Container

Contoh ini menunjukkan cara menentukan komponen di dalam wadah

2 Wadah di dalam wadah

Contoh ini menunjukkan cara mendefinisikan wadah di dalam wadah dengan komponen lain

Ada berbagai jenis kontainer Ext.panel.Panel, Ext.form.Panel, Ext.tab.Panel dan Ext.container.Viewport adalah kontainer yang sering digunakan di Ext JS. Di bawah ini adalah contoh yang menunjukkan bagaimana menggunakan wadah ini.

Sr.No. Jenis Wadah & Deskripsi
1 Ext.panel.Panel

Contoh ini menunjukkan wadah Ext.panel.Panel

2 Ext.form.Panel

Contoh ini menunjukkan wadah Ext.form.Panel

3 Ext.tab.Panel

Contoh ini menunjukkan wadah Ext.tab.Panel

4 Ext.container.Viewport

Contoh ini menunjukkan wadah Ext.container.Viewport

Tata letak adalah cara elemen disusun dalam wadah. Ini bisa horizontal, vertikal, atau lainnya. Ext JS memiliki tata letak berbeda yang ditentukan di perpustakaannya, tetapi kami juga selalu dapat menulis tata letak khusus.

Sr Tidak Tata Letak & Deskripsi
1 Mutlak

Tata letak ini memungkinkan untuk memposisikan item menggunakan koordinat XY di wadah.

2 Akordeon

Tata letak ini memungkinkan untuk menempatkan semua item dalam mode tumpukan (satu di atas yang lain) di dalam wadah.

3 Jangkar

Tata letak ini memberikan hak istimewa kepada pengguna untuk menentukan ukuran setiap elemen yang berkaitan dengan ukuran penampung.

4 Berbatasan

Dalam tata letak ini berbagai panel disarangkan dan dipisahkan oleh batas.

5 Mobil

Ini adalah tata letak default yang menentukan tata letak elemen berdasarkan jumlah elemen.

6 Kartu (TabPanel)

Tata letak ini mengatur berbagai komponen dalam gaya tab. Tab akan ditampilkan di atas wadah. Setiap kali hanya satu tab yang terlihat dan setiap tab dianggap sebagai komponen yang berbeda.

7 Kartu (Wizard)

Dalam tata letak ini, setiap kali elemen datang untuk ruang penampung penuh. Ada bilah alat bawah di wizard untuk navigasi.

8 Kolom

Tata letak ini untuk menampilkan beberapa kolom dalam wadah. Kita dapat menentukan lebar tetap atau persentase ke kolom. Lebar persentase akan dihitung berdasarkan ukuran penuh wadah.

9 Cocok

Dalam tata letak ini, wadah diisi dengan satu panel. Jika tidak ada persyaratan khusus yang terkait dengan tata letak, tata letak ini digunakan.

10 Meja

Sesuai dengan namanya, layout ini menyusun komponen-komponen dalam sebuah wadah dalam format tabel HTML.

11 vBox

Tata letak ini memungkinkan elemen untuk didistribusikan secara vertikal. Ini adalah salah satu tata letak yang paling sering digunakan.

12 hBox

Tata letak ini memungkinkan elemen untuk didistribusikan secara horizontal.

ExtJS UI terdiri dari satu atau banyak widget yang disebut Komponen. Ext Js memiliki berbagai komponen UI yang ditentukan yang dapat disesuaikan sesuai kebutuhan Anda.

Sr Tidak Metode & Deskripsi
1 Kotak

Komponen grid dapat digunakan untuk menampilkan data dalam format tabel.

2 Bentuk

Widget formulir untuk mendapatkan data dari pengguna.

3 Kotak pesan

Kotak pesan pada dasarnya digunakan untuk menampilkan data dalam bentuk kotak peringatan.

4 Grafik

Grafik digunakan untuk merepresentasikan data dalam format gambar.

5 Tip alat

Tip alat digunakan untuk menunjukkan beberapa informasi dasar ketika suatu peristiwa terjadi.

6 Jendela

Widget UI ini digunakan untuk membuat jendela, yang akan muncul saat terjadi peristiwa apa pun.

7 Editor HTML

Editor HTML adalah salah satu komponen UI yang sangat berguna, yang digunakan untuk mengatur gaya data yang dimasukkan pengguna dalam hal font, warna, ukuran, dll.

8 Bilah kemajuan

Menunjukkan kemajuan pekerjaan backend.

Fitur drag and drop adalah salah satu fitur canggih yang ditambahkan untuk mempermudah tugas pengembang. Operasi seret, pada dasarnya, adalah gerakan klik pada beberapa elemen UI, saat tombol mouse ditekan dan mouse digerakkan. Operasi jatuh terjadi ketika tombol mouse dilepaskan setelah operasi tarik.

Sintaksis

Menambahkan kelas seret dan lepas ke target yang dapat diseret.

var dd = Ext.create('Ext.dd.DD', el, 'imagesDDGroup', {
   isTarget: false
});

Menambahkan drag and drop kelas target ke target drappable.

var mainTarget = Ext.create('Ext.dd.DDTarget', 'mainRoom', 'imagesDDGroup', {
   ignoreSelf: false
});

Contoh

Berikut ini adalah contoh sederhana.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-classic/resources/theme-classic-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.application ({
            launch: function() {
               var images = Ext.get('images').select('img');
               Ext.each(images.elements, function(el) {
                  var dd = Ext.create('Ext.dd.DD', el, 'imagesDDGroup', {
                     isTarget: false
                  });
               });
            }
         }); 
         var mainTarget = Ext.create('Ext.dd.DDTarget', 'mainRoom', 'imagesDDGroup', {
            ignoreSelf: false
         });
      </script>
      
      <style>
         #content {
            width:600px;
            height:400px;
            padding:10px;
            border:1px solid #000;
         }
         #images {
            float:left;
            width:40%;
            height:100%;
            border:1px solid Black;
            background-color:rgba(222, 222, 222, 1.0);
         }
         #mainRoom {
            float:left;
            width:55%;
            height:100%;
            margin-left:15px;
            border:1px solid Black;
            background-color:rgba(222, 222, 222, 1.0);
         }
         .image {   
            width:64px;
            height:64px;
            margin:10px;
            cursor:pointer;
            border:1px solid Black;
            display: inline-block;
         }
      </style>
   </head>
   
   <body>
      <div id = "content">   
         <div id = "images"> 
            <img src = "/extjs/images/1.jpg" class = "image" />
            <img src = "/extjs/images/2.jpg" class = "image" />
            <img src = "/extjs/images/3.jpg" class = "image" />
            <img src = "/extjs/images/4.jpg" class = "image" />
            <img src = "/extjs/images/5.jpg" class = "image" />
            <img src = "/extjs/images/6.jpg" class = "image" />
            <img src = "/extjs/images/7.jpg" class = "image" />
            <img src = "/extjs/images/8.jpg" class = "image" />
         </div>
         <div id = "mainRoom"></div>
      </div>
   </body>
</html>

Program di atas akan memberikan hasil sebagai berikut -

Dengan bantuan drag and drop di Extjs, kita dapat memindahkan data dari grid ke grid dan grid ke form. Berikut adalah contoh pemindahan data antara kisi dan formulir.

Seret dan lepas - Kotak ke Kotak

seret dan lepas - Kisi ke Formulir

Ext.js menyediakan sejumlah tema untuk digunakan dalam aplikasi Anda. Anda dapat menambahkan tema yang berbeda menggantikan tema klasik dan melihat perbedaan hasilnya. Ini dilakukan hanya dengan mengganti file CSS tema seperti yang dijelaskan di depan.

Tema Neptunus

Pertimbangkan aplikasi Hello World pertama Anda. Hapus CSS berikut dari aplikasi.

https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-classic/resources/theme-classic-all.css

Tambahkan CSS berikut untuk menggunakan tema Neptune.

https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-neptune/resources/theme-neptune-all.css

Untuk melihat efeknya, coba program berikut ini.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-neptune/resources/theme-neptune-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            Ext.create('Ext.Panel', {
               renderTo: 'helloWorldPanel',
               height: 200,
               width: 600,
               title: 'Hello world',
               html: 'First Ext JS Hello World Program'
            });
         });
      </script>
   </head>
   
   <body>
      <div id = "helloWorldPanel" />
   </body>
</html>

Program di atas akan memberikan hasil sebagai berikut -

Tema Renyah

Pertimbangkan aplikasi Hello World pertama Anda. Hapus CSS berikut dari aplikasi.

https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-classic/resources/theme-classic-all.css

Tambahkan CSS berikut untuk menggunakan tema Neptune.

https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-crisp/resources/theme-crisp-all.css

Untuk melihat efeknya, coba program berikut ini.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-crisp/resources/theme-crisp-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      <script type = "text/javascript">
         Ext.onReady(function() {
            Ext.create('Ext.Panel', {
               renderTo: 'helloWorldPanel',
               height: 200,
               width: 600,
               title: 'Hello world',
               html: 'First Ext JS Hello World Program'
            });
         });
      </script>
   </head>
   
   <body>
      <div id = "helloWorldPanel" />
   </body>
</html>

Program di atas akan memberikan hasil sebagai berikut -

Tema Triton

Pertimbangkan aplikasi Hello World pertama Anda. Hapus CSS berikut dari aplikasi.

https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-classic/resources/theme-classic-all.css

Tambahkan CSS berikut untuk menggunakan tema Triton.

https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-triton/resources/theme-triton-all.css

Untuk melihat efeknya, coba program berikut ini.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-triton/resources/theme-triton-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            Ext.create('Ext.Panel', {
               renderTo: 'helloWorldPanel',
               height: 200,
               width: 600,
               title: 'Hello world',
               html: 'First Ext JS Hello World Program'
            });
         });
      </script>
   </head>
   
   <body>
      <div id = "helloWorldPanel" />
   </body>
</html>

Program di atas akan memberikan hasil sebagai berikut -

Tema Abu-abu

Pertimbangkan aplikasi Hello World pertama Anda. Hapus CSS berikut dari aplikasi.

https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-classic/resources/theme-classic-all.css

Tambahkan CSS berikut untuk menggunakan tema Gray.

https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-gray/resources/theme-gray-all.css

Untuk melihat efeknya, coba program berikut ini.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-gray/resources/theme-gray-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            Ext.create('Ext.Panel', {
               renderTo: 'helloWorldPanel',
               height: 200,
               width: 600,
               title: 'Hello world',
               html: 'First Ext JS Hello World Program'
            });
         });
      </script>
   </head>
   
   <body>
      <div id = "helloWorldPanel" />
   </body>
</html>

Program di atas akan memberikan hasil sebagai berikut -

Acara adalah sesuatu yang dipecat ketika sesuatu terjadi di kelas. Misalnya, ketika tombol diklik atau sebelum / setelah elemen dirender.

Metode Acara Menulis

  • Peristiwa built-in menggunakan pendengar
  • Melampirkan acara nanti
  • Acara khusus

Peristiwa Bawaan Menggunakan Pendengar

Ext JS menyediakan properti pendengar untuk menulis acara dan acara khusus di file Ext JS.

Writing listener in Ext JS

Kami akan menambahkan pendengar di program sebelumnya itu sendiri dengan menambahkan properti mendengarkan ke panel.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-neptune/resources/theme-neptune-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            Ext.create('Ext.Button', {
               renderTo: Ext.getElementById('helloWorldPanel'),
               text: 'My Button',
               
               listeners: {
                  click: function() {
                     Ext.MessageBox.alert('Alert box', 'Button is clicked');	
                  }
               }
            });
         });
      </script> 
   </head>
   
   <body>
      <p> Please click the button to see event listener </p>
      <div id = 'helloWorldPanel' />   <!--  panel will be rendered here-- >
   </body>
</html>

Program di atas akan memberikan hasil sebagai berikut -

Dengan cara ini kita juga bisa menulis banyak kejadian di properti pendengar.

Multiple Events in the Same Listener

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-neptune/resources/theme-neptune-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            Ext.get('tag2').hide()
            Ext.create('Ext.Button', {
               renderTo: Ext.getElementById('helloWorldPanel'),
               text: 'My Button',
               
               listeners: {
                  click: function() {
                     this.hide();
                  },
                  hide: function() {
                     Ext.get('tag1').hide();
                     Ext.get('tag2').show();
                  }
               }
            });
         });           
      </script> 
   </head>
   
   <body>
      <div id = "tag1">Please click the button to see event listener.</div>
      <div id = "tag2">The button was clicked and now it is hidden.</div>
      <div id = 'helloWorldPanel' />   <!--  panel will be rendered here-- >
   </body>
</html>

Melampirkan Acara Nanti

Dalam metode penulisan acara sebelumnya, kami telah menulis acara di pendengar pada saat membuat elemen. Cara lainnya adalah dengan melampirkan acara.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-neptune/resources/theme-neptune-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            var button = Ext.create('Ext.Button', {
               renderTo: Ext.getElementById('helloWorldPanel'),
               text: 'My Button'
            });

            // This way we can attach event to the button after the button is created.
            button.on('click', function() {
               Ext.MessageBox.alert('Alert box', 'Button is clicked');
            });
         });
      </script> 
   </head>
   
   <body>
      <p> Please click the button to see event listener </p>
      <div id = 'helloWorldPanel' />   <!--  panel will be rendered here-- >
   </body>
</html>

Program di atas akan memberikan hasil sebagai berikut -

Acara Kustom

Kita dapat menulis peristiwa khusus di Ext JS dan mengaktifkan peristiwa dengan metode fireEvent. Contoh berikut menjelaskan cara menulis acara khusus.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-neptune/resources/theme-neptune-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            var button = Ext.create('Ext.Button', {
               renderTo: Ext.getElementById('helloWorldPanel'),
               text: 'My Button',
               
               listeners: {
                  myEvent: function(button) {
                     Ext.MessageBox.alert('Alert box', 'My custom event is called');
                  }
               }
            });
            Ext.defer(function() {
               button.fireEvent('myEvent');
            }, 5000);
         }); 
      </script> 
   </head>
   
   <body>
      <p> The event will be called after 5 seconds when the page is loaded. </p>
      <div id = 'helloWorldPanel' />   <!--  panel will be rendered here-- >
   </body>
</html>

Setelah halaman dimuat dan dokumen siap, halaman UI dengan tombol akan muncul dan saat kami menjalankan acara setelah 5 detik, dokumen siap. Kotak peringatan akan muncul setelah 5 detik.

Di sini, kami telah menulis acara khusus 'myEvent' dan kami mengaktifkan acara sebagai button.fireEvent (eventName);

Paket data digunakan untuk memuat dan menyimpan semua data dalam aplikasi.

Paket data memiliki banyak kelas tetapi kelas yang paling penting adalah -

  • Model
  • Store
  • Proxy

Model

Kelas dasar untuk model adalah Ext.data.Model. Ini mewakili entitas dalam aplikasi. Ini mengikat data penyimpanan untuk dilihat. Ini memiliki pemetaan objek data backend ke view dataIndex. Data diambil dengan bantuan toko.

Membuat Model

Untuk membuat model, kita perlu memperluas kelas Ext.data.Model dan kita perlu menentukan bidang, namanya, dan pemetaan.

Ext.define('StudentDataModel', {
   extend: 'Ext.data.Model',
   fields: [
      {name: 'name', mapping : 'name'},
      {name: 'age', mapping : 'age'},
      {name: 'marks', mapping : 'marks'}
   ]
});

Di sini, namanya harus sama dengan dataIndex, yang kita deklarasikan dalam tampilan dan pemetaan harus cocok dengan data, baik statis maupun dinamis dari database, yang akan diambil menggunakan store.

Toko

Kelas dasar untuk toko adalah Ext.data.Store. Ini berisi data yang di-cache secara lokal, yang akan ditampilkan dengan bantuan objek model. Store mengambil data menggunakan proxy, yang memiliki jalur yang ditentukan untuk layanan guna mengambil data backend.

Data penyimpanan dapat diambil dengan dua cara - statis atau dinamis.

Penyimpanan statis

Untuk penyimpanan statis, kami akan memiliki semua data yang ada di toko seperti yang ditunjukkan pada kode berikut.

Ext.create('Ext.data.Store', {
   model: 'StudentDataModel',
   data: [
      { name : "Asha", age : "16", marks : "90" },
      { name : "Vinit", age : "18", marks : "95" },
      { name : "Anand", age : "20", marks : "68" },
      { name : "Niharika", age : "21", marks : "86" },
      { name : "Manali", age : "22", marks : "57" }
   ];
});

Toko Dinamis

Data dinamis dapat diambil menggunakan proxy. Kita dapat memiliki proxy yang dapat mengambil data dari Ajax, Rest, dan Json.

Proksi

Kelas dasar untuk proxy adalah Ext.data.proxy.Proxy. Proksi digunakan oleh Model dan Toko untuk menangani pemuatan dan penyimpanan data Model.

Ada dua jenis proxy

  • Proksi Klien
  • Proxy Server

Proksi Klien

Proksi klien mencakup Memori dan Penyimpanan Lokal menggunakan penyimpanan lokal HTML5.

Proxy Server

Proxy server menangani data dari server jarak jauh menggunakan Ajax, data Json, dan layanan Rest.

Defining proxies in the server

Ext.create('Ext.data.Store', {
   model: 'StudentDataModel',
   proxy : {
      type : 'rest',
      actionMethods : {
         read : 'POST'  // Get or Post type based on requirement
      },
      url : 'restUrlPathOrJsonFilePath', // here we have to include the rest URL path 
      // which fetches data from database or Json file path where the data is stored
      reader: {
         type : 'json',  // the type of data which is fetched is of JSON type
         root : 'data'
      },
   }
});

Ext.js menyediakan fasilitas untuk menggunakan paket font yang berbeda. Paket font digunakan untuk menambahkan kelas berbeda untuk ikon yang tersedia dalam paket.

  • Font-Awesome
  • Font-Pictos

Font-Luar Biasa

Tema baru ExtJS, Triton, memiliki font family font-awesome yang disertakan dalam kerangka itu sendiri, oleh karena itu kami tidak memerlukan persyaratan eksplisit untuk lembar gaya font-mengagumkan.

Berikut ini adalah contoh penggunaan kelas Font-Awesome dalam tema Triton.

Font-Awesome dengan tema Triton

Saat kita menggunakan tema lain selain Triton, kita perlu atau perlu menambahkan lembar gaya untuk font-awesome secara eksplisit.

Berikut adalah contoh penggunaan kelas Font-Awesome tanpa tema Triton.

Font-Awesome dengan tema normal (Tema apa pun selain tema Triton)

Font-Pictos

Font-pictos tidak termasuk dalam framework untuk ExtJS, oleh karena itu kita membutuhkan hal yang sama. Hanya pengguna berlisensi Sencha yang dapat menggunakan font-pictos.

Langkah-langkah untuk Menambahkan Font-Pictos

Step 1 - Membutuhkan kelas font-pictos menggunakan perintah berikut.

"requires": ["font-pictos"]

Step 2 - Sekarang tambahkan kelas pictos sebagai -

iconCls: 'pictos pictos-home'

Gaya Aplikasi mengacu pada penyesuaian pengguna atas tampilan dan nuansa komponen. Penyesuaian ini mungkin termasuk: warna, gradien warna, font, margin / padding, dll. Ext JS 6 memiliki cara baru untuk menata aplikasi.

Ini menggunakan SCSS untuk penataan. SCSS adalah cara yang lebih dinamis untuk menulis kode CSS. Kita bisa menulis variabel di stylesheet kita dengan bantuan ini. Namun, browser tidak dapat memahami SCSS. Itu hanya dapat memahami CSS, maka semua file SCSS harus dikompilasi menjadi CSS ke kode siap produksi.

Dengan demikian, file SCSS disebut file preprocessor. Di Ext.js, kompilasi dilakukan melalui alat Sencha CMD. Sencha CMD mengkompilasinya secara manual hanya sekali menggunakan perintah berikut.

sencha app build [development]

Global_CSS adalah file CSS utama, yang memiliki semua variabel SCSS yang terkait dengannya di ExtJS yang dapat digunakan dalam aplikasi kita untuk menyesuaikan tema kita dengan memberikan nilai yang berbeda berdasarkan kebutuhan kita.

Berikut adalah beberapa variabel CSS yang tersedia di Global_CSS di Ext.js.

Sr Tidak Variabel & Deskripsi
1

$base-color

$ base-color: color (mis. $ base-color: # 808080)

Warna dasar ini akan digunakan di seluruh tema.

2

$base-gradient

$ base-gradient: string (misal $ base-gradient: 'matte')

Gradien dasar ini akan digunakan di seluruh tema.

3

$body-background-color

$ body-background-color: color (mis. $ body-background-color: # 808080)

Warna latar belakang untuk diterapkan ke elemen tubuh. Jika disetel ke transparan atau 'tidak ada', tidak ada gaya warna latar belakang yang akan disetel pada elemen badan.

4

$color

$ color: color (mis. $ color: # 808080)

Warna teks default ini akan digunakan di seluruh tema.

5

$font-family

$ font-family: string (misal $ font-family: arial)

Keluarga font default ini akan digunakan di seluruh tema.

6

$font-size

$ font-size: number (mis. $ font-size: 9px)

Ukuran font default ini akan digunakan di seluruh tema.

7

$font-weight

$ font-weight: string / number (mis. $ font-weight: normal)

Font-weight default ini akan digunakan di seluruh tema.

8

$font-weight-bold

$ font-weight-bold: string / number (mis. $ font-weight-bold: bold)

Font-weight default untuk font tebal ini akan digunakan di seluruh tema.

9

$include-chrome

$ include-chrome: boolean (mis. $ include-chrome: true)

Benar untuk menyertakan aturan khusus Chrome.

10

$include-ff

$ include-ff: boolean (mis. $ include-ff: true)

Benar untuk menyertakan aturan khusus Firefox.

11

$include-ie

$ include-ie: boolean (mis. $ include-ie: true)

Benar untuk menyertakan aturan khusus Internet Explorer untuk IE9 dan yang lebih rendah.

12

$include-opera

$ include-opera: boolean (misalnya $ include-opera: true)

Benar untuk memasukkan aturan khusus Opera.

13

$include-safari

$ include-safari: boolean (mis. $ include-safari: true)

Benar untuk memasukkan aturan khusus Opera.

14

$include-webkit

$ include-webkit: boolean (mis. $ include-webkit: true)

Benar untuk menyertakan aturan khusus Webkit.

Paket gambar di ExtJS memungkinkan Anda menggambar grafik tujuan umum. Ini dapat digunakan untuk grafik yang berfungsi di semua browser dan perangkat seluler.

Sr Tidak Gambar
1 Lingkaran

Grafik ini digunakan untuk membuat bentuk lingkaran.

2 Empat persegi panjang

Grafik ini digunakan untuk membuat bentuk persegi panjang.

3 Busur

Grafik ini digunakan untuk membuat bentuk busur.

4 Elips

Grafik ini digunakan untuk membuat bentuk elips.

5 EllipticalArc

Grafik ini digunakan untuk membuat bentuk busur elips.

6 Gambar

Grafik ini digunakan untuk menambahkan gambar ke aplikasi Anda.

7 Jalan

Grafik ini digunakan untuk membuat jalur bebas.

8 Teks

Grafik ini digunakan untuk menambahkan teks apa pun ke aplikasi Anda.

9 Terjemahkan setelah dirender

Properti ini digunakan untuk memindahkan titik awal dalam penampung Anda, setelah grafik dirender. Ini dapat digunakan dengan grafik apa pun.

10 Rotasi

Properti ini digunakan untuk menambahkan rotasi ke gambar yang ditambahkan. Ini dapat digunakan dengan grafik apa pun.

11 Kotak

Grafik ini digunakan untuk membuat persegi.

Itu selalu yang terbaik untuk berkomunikasi dengan pengguna dalam bahasa yang mereka pahami dan sukai. Paket pelokalan extjs mendukung lebih dari 40 bahasa seperti Jerman, Perancis, Korea, Cina, dll. Sangat mudah untuk mengimplementasikan lokal di ExtJs. Anda akan menemukan semua file lokal yang dibundel di folder override dari paket ext-locale. File lokal hanya menimpa yang memberi tahu Ext JS untuk mengganti nilai bahasa Inggris default dari komponen tertentu.

Program berikut adalah untuk menunjukkan bulan di lokasi yang berbeda untuk melihat efeknya. Coba program berikut ini.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-classic/resources/theme-classic-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-fr.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            var monthArray = Ext.Array.map(Ext.Date.monthNames, function (e) { return [e]; });
            var ds = Ext.create('Ext.data.Store', {
               fields: ['month'],
               remoteSort: true,
               pageSize: 6,
               
               proxy: {
                  type: 'memory',
                  enablePaging: true,
                  data: monthArray,
                  reader: {type: 'array'}
               }
            });
            Ext.create('Ext.grid.Panel', {
               renderTo: 'grid',
               id : 'gridId',
               width: 600,
               height: 200,
               title:'Month Browser',
               
               columns:[{
                  text: 'Month of the year',
                  dataIndex: 'month',
                  width: 300
               }],
               store: ds,
               bbar: Ext.create('Ext.toolbar.Paging', {
                  pageSize: 6,
                  store: ds,
                  displayInfo: true
               })
            }); 
            Ext.getCmp('gridId').getStore().load();
         });
      </script>
   </head>
   
   <body>
      <div id = "grid" />
   </body>
</html>

Program di atas akan menghasilkan hasil sebagai berikut

Untuk menggunakan bahasa lokal selain bahasa Inggris, kami perlu menambahkan file khusus lokal dalam program kami. Di sini kami menggunakan https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/localefr.js untuk bahasa Prancis. Anda dapat menggunakan lokal yang berbeda untuk bahasa yang berbeda seperti https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-ko.js untuk bahasa Korea, dll.

Program berikut adalah untuk menunjukkan pemilih tanggal dalam bahasa Korea untuk melihat efeknya. Coba program berikut ini.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-classic/resources/theme-classic-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-ko.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function() {
            Ext.create('Ext.picker.Date', {
               renderTo: 'datePicker'
            });
         });
      </script>
   </head>
   
   <body>
      <div id = "datePicker" />
   </body>
</html>

Program di atas akan memberikan hasil sebagai berikut -

Tabel berikut mencantumkan beberapa lokal yang tersedia di ExtJS dan URL lokal file utama yang akan diubah.

Lokal Bahasa URL Lokal
ko Korea https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-ko.js
fr Perancis https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-fa.js
es Orang Spanyol https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-es.js
ja Jepang https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-ja.js
Itu Italia https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-it.js
ru Rusia https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-ru.js
zh_CN Menyederhanakan bahasa Mandarin https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/localezh_CN.js

Secara umum aksesibilitas berarti ketersediaan, konten dapat diakses berarti konten tersedia.

Dalam istilah perangkat lunak, aplikasi dapat diakses artinya aplikasi tersedia untuk semua. Di sini, semua berarti penyandang disabilitas, tunanetra atau mereka yang menggunakan pembaca layar untuk menggunakan komputer atau mereka yang lebih memilih untuk menavigasi menggunakan keyboard daripada menggunakan mouse. navigasi dengan keyboard daripada menggunakan mouse.

Aplikasi yang dapat diakses disebut ARIA (Aplikasi Internet Kaya yang Dapat Diakses).

Aksesibilitas di Ext JS

Ext JS dirancang untuk mengingat bahwa ini harus bekerja dengan semua navigasi keyboard. Ini memiliki pengindeksan tab bawaan dan kemampuan fokus, dan selalu aktif secara default sehingga kami tidak perlu menambahkan properti apa pun untuk mengaktifkan fungsionalitas ini.

Fungsionalitas ini memungkinkan semua komponen yang mendukung keyboard untuk berinteraksi dengan pengguna saat masuk ke tab. Misalnya, kita dapat menggunakan tab untuk berpindah ke komponen berikutnya daripada mouse. Dengan cara yang sama, kita dapat menggunakan shift + tab untuk mundur dan menggunakan enter pada keyboard untuk mengklik, dll.

Fokus Styling dan Tab

Fokus ada di dalam Extjs saat menggunakan keystroke untuk tabbing.

Contoh berikut memperlihatkan bagaimana gaya berubah, ketika fokus berubah dengan tab.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-crisp/resources/theme-crisp-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.onReady(function(){
            Ext.create('Ext.Button', {
               renderTo: Ext.getElementById('button1'),
               text: 'Button1',
               
               listeners: {
                  click: function() {
                     Ext.MessageBox.alert('Alert box', 'Button 1 is clicked');	
                  }
               }
            });
            Ext.create('Ext.Button', {
               renderTo: Ext.getElementById('button2'),
               text: 'Button2',
               
               listeners: {
                  click: function() {
                     Ext.MessageBox.alert('Alert box', 'Button 2 is clicked');	
                  }
               }
            });
            Ext.create('Ext.Button', {
               renderTo: Ext.getElementById('button3'),
               text: 'Button3',
               
               listeners: {
                  click: function() {
                     Ext.MessageBox.alert('Alert box', 'Button 3 is clicked');	
                  }
               }
            });
         });     
      </script>
   </head>
   
   <body> <p>Please click the button to see event listener:</p>
      <span id = "button3"/>
      <span id = "button2"/>
      <span id = "button1"/>
   </body>
</html>

Untuk melihat efeknya, gunakan tab untuk berpindah dari tombol berikutnya dan shft + tab untuk fokus ke belakang. Gunakan enter dan lihat bagaimana peringatan terkait tombol fokus akan muncul.

Tema ARIA

ExtJS menyediakan tema aria untuk tunanetra.

Contoh berikut menunjukkan tema aria yang mudah diakses oleh tunanetra.

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/theme-aria/resources/theme-aria-all.css" 
         rel = "stylesheet" />
      <script type = "text/javascript" 
         src = "https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/ext-all.js"></script>
      
      <script type = "text/javascript">
         Ext.require([
            'Ext.grid.*',
            'Ext.data.*'
         ]);
         
         // Creation of data model
         Ext.define('StudentDataModel', {
            extend: 'Ext.data.Model',
            fields: [
               {name: 'name', mapping : 'name'},
               {name: 'age', mapping : 'age'},
               {name: 'marks', mapping : 'marks'}
            ]
         });

         Ext.onReady(function() {
            // Store data
            var myData = [
               { name : "Asha", age : "16", marks : "90" },
               { name : "Vinit", age : "18", marks : "95" },
               { name : "Anand", age : "20", marks : "68" },
               { name : "Niharika", age : "21", marks : "86" },
               { name : "Manali", age : "22", marks : "57" }
            ];
            
            // Creation of first grid store
            var firstGridStore = Ext.create('Ext.data.Store', {
               model: 'StudentDataModel',
               data: myData
            });
            
            // Creation of first grid
            var firstGrid = Ext.create('Ext.grid.Panel', {
               store            : firstGridStore,
               columns          :
               [{ 
                  header: "Student Name",
                  dataIndex: 'name',	
                  id : 'name',    
                  flex:  1,  			
                  sortable: true
               },{
                  header: "Age", 
                  dataIndex: 'age',
                  flex: .5, 
                  sortable: true
               },{
                  header: "Marks",
                  dataIndex: 'marks',
                  flex: .5, 
                  sortable: true
               }],
               stripeRows       : true,
               title            : 'First Grid',
               margins          : '0 2 0 0'
            });
     
            // Creation of a panel to show both the grids.
            var displayPanel = Ext.create('Ext.Panel', {
               width        : 600,
               height       : 200,
               
               layout       : {
                  type: 'hbox',
                  align: 'stretch',
                  padding: 5
               },
               renderTo     : 'panel',
               defaults     : { flex : 1 }, 
               items        : [ 
                  firstGrid
               ]
            });
         });
      </script>
   </head>
   
   <body>
      <div id = "panel" > </div>
   </body>
</html>

Program di atas akan menghasilkan hasil sebagai berikut. Anda dapat menggunakan tombol atas dan bawah tab dan mouse untuk memindahkan fokus melintasi kisi dan tema pada dasarnya untuk orang-orang tunanetra.

Kode JavaScript apa pun dapat di-debug menggunakan alert() kotak atau console.log() atau dengan penunjuk debug di debugger.

Kotak Peringatan

Tempatkan kotak peringatan di kode tempat Anda ingin memeriksa aliran atau nilai variabel apa pun. Misalnya, alert ('message to show' + variabel);

Alat Pengembangan / Debugging

Debugger adalah alat terpenting bagi pengembang mana pun untuk memeriksa masalah dan kesalahan dalam kode saat mengembangkan.

Ext JS adalah kerangka kerja JavaScript, sehingga dapat dengan mudah di-debug menggunakan alat pengembang yang disediakan oleh atau khusus untuk browser yang berbeda. Semua browser utama memiliki alat pengembangnya untuk menguji dan men-debug kode JavaScript.

Debugger populer adalah alat pengembangan IE untuk IE, firebug untuk firefox, dan alat pengembangan chrome untuk browser Chrome.

Debugger Chrome hadir dengan browser Chrome, namun firebug harus dipasang secara khusus karena tidak disertakan sebagai paket dengan firefox.

Berikut ini link untuk menginstal firebug untuk browser firefox http://getfirebug.com

Pintasan untuk membuka alat pengembangan di OS Windows adalah tombol keyboard F12.

Debugging Kode JS di Debugger

Ada dua cara untuk men-debug kode JavaScript.

  • Cara pertama, adalah menempatkan console.log() dalam kode dan melihat nilai log, yang akan dicetak di konsol alat pengembangan.

  • Cara kedua adalah dengan menggunakan breakpoint di alat pengembangan. Berikut prosesnya.

    • Buka file di semua skrip yang tersedia di bawah tag skrip.

    • Sekarang tempatkan breakpoint ke baris yang ingin Anda debug.

    • Jalankan aplikasi di browser.

    • Sekarang, setiap kali aliran kode akan mencapai baris ini, itu akan memecahkan kode dan tetap di sana sampai pengguna menjalankan kode dengan kunci F6 (pergi ke baris kode berikutnya), F7 (masuk ke dalam fungsi) atau F8 (masuk ke breakpoint berikutnya atau jalankan kode jika tidak ada lagi breakpoint) berdasarkan aliran yang ingin Anda debug.

    • Anda dapat memilih variabel atau fungsi yang ingin Anda lihat nilainya.

    • Anda dapat menggunakan konsol untuk memeriksa nilai atau untuk memeriksa beberapa perubahan di browser itu sendiri.

Berikut adalah beberapa fungsi bawaan, yang banyak digunakan di Ext JS.

Ekst. Kelas

Kelas ini memeriksa platform yang Anda gunakan, apakah itu ponsel atau desktop, sistem operasi mac atau Windows. Ini adalah metode berikut yang terkait dengan kelas Ext.is.

Sr Tidak Metode & Deskripsi
1

Ext.is.Platforms

Fungsi ini mengembalikan platform yang tersedia untuk versi ini.

Misalnya, ketika Anda menjalankan fungsi berikut, ini mengembalikan sesuatu seperti ini -

[Object { property = "platform", regex = RegExp, identity = "iPhone"}, 
Object { property = "platform", regex = RegExp, identity = "iPod"}, 
Object { property = "userAgent", regex = RegExp, identity = "iPad"}, 
Object { property = "userAgent", regex = RegExp, identity = "Blackberry"}, 
Object { property = "userAgent", regex = RegExp, identity = "Android"}, 
Object { property = "platform", regex = RegExp, identity = "Mac"}, 
Object { property = "platform", regex = RegExp, identity = "Windows"}, 
Object { property = "platform", regex = RegExp, identity = "Linux"}]
2

Ext.is.Android

Fungsi ini akan mengembalikan nilai true, jika Anda menggunakan sistem operasi Android, jika tidak maka akan mengembalikan false.

3

Ext.is.Desktop

Fungsi ini akan mengembalikan nilai true, jika Anda menggunakan desktop untuk aplikasi, jika tidak maka akan mengembalikan false.

4

Ext.is.Phone

Fungsi ini akan mengembalikan nilai true, jika Anda menggunakan ponsel, jika tidak maka akan mengembalikan false.

5

Ext.is.iPhone

Fungsi ini akan mengembalikan nilai true jika Anda menggunakan iPhone, jika tidak maka akan mengembalikan nilai salah.

6

Ext.is.iPod

Fungsi ini akan mengembalikan nilai true, jika Anda menggunakan iPod, jika tidak maka akan mengembalikan false.

7

Ext.is.iPad

Fungsi ini akan mengembalikan nilai true, jika Anda menggunakan iPad, jika tidak maka akan mengembalikan false.

8

Ext.is.Windows

Fungsi ini akan mengembalikan nilai true, jika Anda menggunakan sistem operasi Windows, jika tidak maka akan mengembalikan false.

9

Ext.is.Linux

Fungsi ini akan mengembalikan nilai true, jika Anda menggunakan sistem operasi Linux, jika tidak maka akan mengembalikan false.

10

Ext.is.Blackberry

Fungsi ini akan mengembalikan nilai true, jika Anda menggunakan Blackberry, jika tidak maka akan mengembalikan false.

11

Ext.is.Mac

Fungsi ini akan mengembalikan nilai true, jika Anda menggunakan sistem operasi Mac, jika tidak maka akan mengembalikan false.

Ext. Mendukung Kelas

Seperti namanya, kelas ini memberikan informasi apakah fitur tersebut didukung oleh lingkungan browser / perangkat saat ini atau tidak.

Sr Tidak Metode & Deskripsi
1

Ext.supports.History

Ia memeriksa apakah perangkat mendukung sejarah HTML 5 sebagai window.history atau tidak. Jika perangkat mendukung sejarah, maka itu kembalitrue, kalau tidak salah.

2

Ext.supports.GeoLocation

Ia memeriksa apakah perangkat mendukung metode geolokasi atau tidak. Secara internal ia memeriksa metode navigator.geolocation.

3

Ext.supports.Svg

Ia memeriksa apakah perangkat mendukung metode HTML 5 fitur scalable vector graphics (svg) atau tidak. Secara internal ia memeriksa doc.createElementNS && !! doc.createElementNS ("http: /" + "/www.w3.org/2000/svg", "svg"). CreateSVGRect.

4

Ext.supports.Canvas

Ia memeriksa apakah perangkat mendukung kanvas fitur HTML 5 untuk menggambar metode atau tidak. Secara internal, ia memeriksa doc.createElement ('canvas'). GetContext dan mengembalikan nilai berdasarkan keluaran metode ini.

5

Ext.supports.Range

Ia memeriksa apakah browser mendukung metode document.createRange atau tidak.

Kelas Ekst.String

Kelas ext.String memiliki berbagai metode untuk bekerja dengan data string. Metode yang paling sering digunakan adalah encoding decoding, trim, toggle, urlAppend, dll.

Encoding Decoding function - Ini adalah fungsi yang tersedia di kelas Ext.String untuk menyandikan dan mendekode nilai HTML.

Sr Tidak Metode & Deskripsi
1

Ext.String.htmlEncode

Fungsi ini digunakan untuk menyandikan nilai html agar dapat diuraikan.

Example -

Ext.String.htmlEncode("< p > Hello World < /p >"); 
Output - "&lt; p &gt; Hello World &lt; /p &gt;".
2

Ext.String.htmlDecode

Fungsi ini digunakan untuk memecahkan kode nilai html yang dikodekan.

Example -

Ext.String.htmlDecode("&lt; p &gt; Hello World &lt; /p &gt;");
Output -  "< p > Hello World < /p >"
3

Ext.String.trim

Fungsi ini untuk memangkas ruang yang tidak diinginkan dalam string.

Ext.String.trim('      hello      ');
Output – "hello"
4

Ext.String.urlAppend

Metode ini digunakan untuk menambahkan nilai dalam string URL.

Example -

Ext.String.urlAppend('https://www.google.com' , 'hello'); 
Output - "https://www.google.com?hello" 
Ext.String.urlAppend('https://www.google.com?index=1' , 'hello'); 
Output – "https://www.google.com?index=1&hello"
5

Ext.String.toggle

Fungsi ini untuk mengubah nilai antara dua nilai yang berbeda.

Example -

var toggleString = 'ASC' 
toggleString = Ext.String.toggle(a, 'ASC', 'DESC');
Output – DESC as toggleString had value ASC. Now again, if we 
print the same we will get toggleString = “ASC” this time, as 
it had value 'DESC'. 
It is similar to ternary operator 
toggleString = ((toggleString =='ASC')? 'DESC' : 'ASC' );

Metode Lain-lain

Sr Tidak Metode & Deskripsi
1

Ext.userAgent()

Fungsi ini memberikan informasi tentang browser userAgent. UserAgent adalah mengidentifikasi browser dan sistem operasi ke server web.

Example - Jika Anda bekerja di Mozilla, ia mengembalikan sesuatu seperti: "mozilla / 5.0 (windows nt 6.1; wow64; rv: 43.0) gecko / 20100101 firefox / 43.0"

2

Version related function

Fungsi ini mengembalikan versi browser yang sedang digunakan, jika fungsi tersebut disebut terkait dengan IE. Di browser Firefox, ia mengembalikan 0. Fungsi-fungsi ini adalah Ext.firefoxVersion, Ext.ieVersion, dll.

Example - Jika Anda menggunakan browser Firefox dan Anda memanggil metode Ext.ieVersion untuk mengambil versi IE, maka akan mengembalikan 0. Jika Anda menggunakan metode yang sama di browser IE, maka metode ini akan mengembalikan versi yang Anda gunakan seperti 8 , 9, dll.

3

Ext.getVersion()

Fungsi ini mengembalikan versi Ext JS yang sedang digunakan.

Example - Jika Anda memanggil Ext.getVersion (), ini mengembalikan array nilai seperti versi, versi pendek, dll.

Ext.getVersion (). Version mengembalikan versi Ext JS saat ini yang digunakan dalam program, seperti "4.2.2".

4

Browser related functions

Fungsi ini mengembalikan nilai Boolean berdasarkan browser yang digunakan. Metode ini adalah Ext.isIE, Ext.isIE6, Ext.isFF06, dan Ext.isChrome.

Example - Jika Anda menggunakan browser Chrome, maka fungsi Ext.isChrome akan mengembalikan true all, jika tidak maka akan mengembalikan false.

5

Ext.typeOf()

Fungsi ini mengembalikan tipe data variabel.

Example -

var a = 5;   
var b  = 'hello'; 
Ext.typeOf(a); 
Output – Number 
Ext.typeOf(b);
Output - String
6

DataType related methods - Fungsi-fungsi ini mengembalikan nilai boolean berdasarkan tipe data variabel

Example -

var a = ['a', 'bc'];
var b = 'hello';
var c = 123;
var emptyVariable;
var definedVariable;
function extraFunction(){return true;}
Ext.isArray (a); // mengembalikan nilai true
Ext.isString (b); // return true
Ext.isNumber (c); // return true
Ext.isEmpty (emptyVariable); // return true
Ext.isEmpty (b); // return false
Ext.isDefined (definedVariable); // return true
Ext.isfunction (extraFunction); // return true