Ext.js - Système de classes

Ext JS est un framework JavaScript ayant des fonctionnalités de programmation orientée objet. Ext est l'espace de noms, qui encapsule toutes les classes dans Ext JS.

Définition d'une classe dans Ext JS

Ext fournit plus de 300 classes, que nous pouvons utiliser pour diverses fonctionnalités.

Ext.define () est utilisé pour définir les classes dans Ext JS.

Syntaxe

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

Le nom de la classe est le nom de la classe selon la structure de l'application. Par exemple, appName.folderName.ClassName studentApp.view.StudentView.

Les propriétés / membres de la classe définissent le comportement de la classe.

La fonction de rappel est facultative. Il est appelé lorsque la classe s'est chargée correctement.

Exemple de définition de classe 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'
   }]
});

Création d'objets

Comme pour les autres langages basés sur OOPS, nous pouvons également créer des objets dans Ext JS.

Voici les différentes façons de créer des objets dans Ext JS.

Utiliser un nouveau mot-clé

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

Utiliser Ext.create ()

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

Héritage dans Ext JS

L'héritage est le principe d'utilisation des fonctionnalités définies dans la classe A dans la classe B.

Dans Ext JS, l'héritage peut être effectué en utilisant deux méthodes -

Ext.extend

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

Ici, notre classe personnalisée StudentDetailsGrid utilise les fonctionnalités de base de la classe Ext JS GridPanel.

Utilisation de mixins

Mixins est une manière différente d'utiliser la classe A dans la classe B sans extension.

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

Les mixins sont ajoutés dans le contrôleur où nous déclarons toutes les autres classes telles que store, view, etc. De cette façon, nous pouvons appeler la classe DepartmentUtils et utiliser ses fonctions dans le contrôleur ou dans cette application.