Ext.js - Guide rapide

Ext JS est un framework JavaScript populaire qui fournit une interface utilisateur riche pour la création d'applications Web avec des fonctionnalités inter-navigateurs. Ext JS est essentiellement utilisé pour créer des applications de bureau. Il prend en charge tous les navigateurs modernes tels que IE6 +, FF, Chrome, Safari 6+, Opera 12+, etc. Alors qu'un autre produit de Sencha, Sencha Touch est utilisé pour les applications mobiles.

Ext JS est basé sur l'architecture MVC / MVVM. La dernière version d'Ext JS 6 est une plate-forme unique, qui peut être utilisée à la fois pour les applications de bureau et mobiles sans avoir de code différent pour différentes plates-formes.

L'histoire

Ext JS 1.1

La première version d'Ext JS a été développée par Jack Slocum en 2006. C'était un ensemble de classes utilitaires, qui est une extension de YUI. Il a nommé la bibliothèque YUI-ext.

Ext JS 2.0

Ext JS version 2.0 a été publié en 2007. Cette version avait une nouvelle documentation API pour les applications de bureau avec des fonctionnalités limitées. Cette version n'a pas de compatibilité descendante avec la version précédente d'Ext JS.

Ext JS 3.0

Ext JS version 3.0 a été publié en 2009. Cette version a ajouté de nouvelles fonctionnalités comme des graphiques et des vues de liste, mais au détriment de la vitesse. Il avait une compatibilité descendante avec la version 2.0.

Ext JS 4.0

Après la sortie d'Ext JS 3, les développeurs d'Ext JS ont eu le défi majeur d'augmenter la vitesse. Ext JS version 4.0 a été publié en 2011. Il avait la structure révisée complète, qui a été suivie par l'architecture MVC et une application rapide.

Ext JS 5.0

Ext JS version 5.0 a été publié en 2014. Le changement majeur dans cette version a été de changer l'architecture MVC en architecture MVVM. Il comprend la possibilité de créer des applications de bureau sur des appareils tactiles, une liaison de données bidirectionnelle, des mises en page réactives et de nombreuses autres fonctionnalités.

Ext JS 6.0

Ext JS 6 fusionne le framework Ext JS (pour application de bureau) et Sencha Touch (pour application mobile).

traits

Voici les fonctionnalités mises en évidence d'Ext JS.

  • Widgets d'interface utilisateur personnalisables avec collection d'interfaces utilisateur riches telles que des grilles, des grilles de pivot, des formulaires, des graphiques, des arbres.

  • Compatibilité du code des nouvelles versions avec l'ancienne.

  • Un gestionnaire de mise en page flexible permet d'organiser l'affichage des données et du contenu sur plusieurs navigateurs, appareils et tailles d'écran.

  • Le package de données Advance dissocie les widgets d'interface utilisateur de la couche de données. Le package de données permet la collecte de données côté client à l'aide de modèles hautement fonctionnels qui permettent des fonctionnalités telles que le tri et le filtrage.

  • Il est indépendant du protocole et peut accéder aux données de n'importe quelle source back-end.

  • Thèmes personnalisables Les widgets Ext JS sont disponibles dans plusieurs thèmes prêts à l'emploi qui sont cohérents entre les plates-formes.

Avantages

Sencha Ext JS est la principale norme pour le développement d'applications Web de niveau professionnel. Ext JS fournit les outils nécessaires pour créer des applications robustes pour les ordinateurs de bureau et les tablettes.

  • Rationalise le développement multiplateforme sur les ordinateurs de bureau, les tablettes et les smartphones - pour les navigateurs modernes et hérités.

  • Augmente la productivité des équipes de développement en s'intégrant aux environnements de développement d'entreprise via des plugins IDE.

  • Réduit le coût du développement d'applications Web.

  • Permet aux équipes de créer des applications avec une expérience utilisateur convaincante.

  • Propose un ensemble de widgets pour créer facilement une interface utilisateur puissante.

  • Suit l'architecture MVC, le code est donc hautement lisible.

Limites

  • La taille de la bibliothèque est importante, environ 500 Ko, ce qui augmente le temps de chargement initial et ralentit l'application.

  • Le HTML regorge de balises qui le rendent complexe et difficile à déboguer.

  • Selon la politique générale des licences publiques, il est gratuit pour les applications open source mais payant pour les applications commerciales.

  • Parfois, pour le chargement, même des choses simples nécessitent quelques lignes de codage, ce qui est plus simple en html ou JQuery.

  • Besoin d'un développeur assez expérimenté pour développer des applications Ext JS.

Outils

Voici les outils fournis par Sencha utilisés pour le développement d'applications Ext JS principalement au niveau de la production.

Sencha CMD

Sencha CMD est un outil qui fournit les fonctionnalités de minification de code Ext JS, d'échafaudage et de génération de build de production.

Plugins IDE Sencha

Les plugins Sencha IDE intègrent les frameworks Sencha dans les IDE IntelliJ, WebStorm, ce qui aide à améliorer la productivité du développeur en fournissant des fonctionnalités telles que la complétion de code, l'inspection du code, la navigation dans le code, la génération de code, la refactorisation de code, la création de modèles, la vérification orthographique, etc.

Inspecteur Sencha

Sencha Inspector est un outil de débogage qui aide le débogueur à déboguer tout problème lors du développement.

Configuration de l'environnement local

Cette section vous explique comment télécharger et configurer Ext JS sur votre machine. Veuillez suivre les étapes pour configurer l'environnement.

Téléchargement de fichiers de bibliothèque

Téléchargez la version d'essai des fichiers de bibliothèque Ext JS à partir de Sencha https://www.sencha.com. Vous obtiendrez la version d'essai du site sur votre identifiant de messagerie enregistré, qui sera un dossier zippé nommé ext-6.0.1-trial.

Décompressez le dossier et vous trouverez divers fichiers JavaScript et CSS, que vous incluerez dans notre application. Nous inclurons principalement les fichiers suivants -

JavaScript Files - Le fichier JS que vous pouvez trouver sous le dossier \ ext-6.0.1-trial \ ext6.0.1 \ build sont -

Sr. Non Description du fichier
1

ext.js

Il s'agit du fichier principal qui contient toutes les fonctionnalités pour exécuter l'application.

2

ext-all.js

Ce fichier contient tout le code minifié sans commentaires dans le fichier.

3

ext-all-debug.js

Il s'agit de la version non réduite d'ext-all.js à des fins de débogage.

4

ext-all-dev.js

Ce fichier est également non réduit et est utilisé à des fins de développement car il contient tous les commentaires et les journaux de la console pour vérifier les erreurs / problèmes.

5

ext-all.js

Ce fichier est principalement utilisé à des fins de production car il est beaucoup plus petit que tout autre.

Vous pouvez ajouter ces fichiers au dossier JS de vos projets ou vous pouvez fournir un chemin direct où le fichier réside dans votre système.

CSS Files - Il existe un certain nombre de fichiers basés sur des thèmes, que vous pouvez trouver dans le dossier \ ext6.0.1-trial \ ext-6.0.1 \ build \ classic \ theme-classic \ resources \ theme-classic-all.css

  • Si vous envisagez d'utiliser une application de bureau, vous pouvez utiliser des thèmes classiques dans le dossier \ ext-6.0.1-trial \ ext-6.0.1 \ build \ classic

  • Si nous allons utiliser une application mobile, vous pouvez utiliser des thèmes modernes qui se trouvent dans le dossier \ ext-6.0.1-trial \ ext-6.0.1 \ build \ modern

Les fichiers de bibliothèque suivants seront ajoutés dans une application 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>

Vous conserverez le code d'application ExtJS dans le fichier app.js.

Configuration CDN

CDN est un réseau de diffusion de contenu avec lequel vous n'avez pas besoin de télécharger les fichiers de bibliothèque Ext JS, à la place vous pouvez directement ajouter un lien CDN pour ExtJS à votre programme comme suit -

<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>

Rédacteurs populaires

Comme il s'agit d'un framework JavaScript, qui est utilisé pour développer des applications Web, dans notre projet, nous aurons des fichiers HTML, JS. Pour écrire nos programmes Ext JS, nous aurons besoin d'un éditeur de texte. Il existe même plusieurs IDE disponibles sur le marché. Mais pour l'instant, nous pouvons envisager l'un des éléments suivants -

  • Notepad - Sur une machine Windows, vous pouvez utiliser n'importe quel éditeur de texte simple tel que Notepad (recommandé pour ce tutoriel), Notepad ++, sublime.

  • Eclipse - C'est un IDE développé par la communauté open-source eclipse et peut être téléchargé depuis https://www.eclipse.org/.

Navigateur

Ext JS prend en charge la compatibilité entre navigateurs, il prend en charge tous les principaux navigateurs tels que -

  • IE 6 et supérieur
  • Firefox 3.6 et supérieur
  • Chrome10 et supérieur
  • Safari 4 et supérieur
  • Opera 11 et supérieur

Vous pouvez utiliser n'importe quel navigateur pour exécuter l'application Ext JS.

La convention de dénomination est un ensemble de règles à suivre pour les identificateurs. Cela rend le code plus lisible et compréhensible pour les autres programmeurs.

La convention de dénomination dans Ext JS suit la convention JavaScript standard, ce qui n'est pas obligatoire mais une bonne pratique à suivre. Il doit suivre la syntaxe de cas de camel pour nommer la classe, la méthode, la variable et les propriétés.

Si le nom est combiné avec deux mots, le deuxième mot commencera toujours par une lettre majuscule. Par exemple, doLayout (), StudentForm, firstName, etc.

Nom Convention
Nom du cours Il doit commencer par une lettre majuscule, suivie de la casse du chameau. Par exemple, StudentClass
Nom de la méthode Il doit commencer par une lettre minuscule, suivie de la casse du chameau. Par exemple, doLayout ()
Nom de variable Il doit commencer par une lettre minuscule, suivie de la casse du chameau. Par exemple, firstName
Nom de la constante Il doit être uniquement en majuscules. Par exemple, COUNT, MAX_VALUE
Nom de la propriété Il doit commencer par une lettre minuscule, suivie de la casse du chameau. Par exemple, enableColumnResize = true

Ext JS suit l'architecture MVC / MVVM.

MVC - Architecture Model View Controller (version 4)

MVVM - Model View Viewmodel (version 5)

Cette architecture n'est pas obligatoire pour le programme, cependant, il est recommandé de suivre cette structure pour rendre votre code hautement maintenable et organisé.

Structure de projet avec l'application 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

Le dossier de l'application Ext JS résidera dans le dossier JavaScript de votre projet.

L'application contiendra des fichiers de contrôleur, de vue, de modèle, de magasin et d'utilitaire avec app.js.

app.js- Le fichier principal à partir duquel le flux du programme démarrera, qui devrait être inclus dans le fichier HTML principal en utilisant la balise <script>. L'application appelle le contrôleur de l'application pour le reste de la fonctionnalité.

Controller.js- Il s'agit du fichier contrôleur de l'architecture Ext JS MVC. Il contient tout le contrôle de l'application, les écouteurs d'événements et la plupart des fonctionnalités du code. Il a le chemin défini pour tous les autres fichiers utilisés dans cette application tels que stocker, afficher, modèle, require, mixins.

View.js- Il contient la partie interface de l'application, qui apparaît à l'utilisateur. Ext JS utilise diverses vues riches de l'interface utilisateur, qui peuvent être étendues et personnalisées ici en fonction des besoins.

Store.js- Il contient les données mises en cache localement qui doivent être rendues sur la vue à l'aide d'objets de modèle. Store récupère les données à l'aide de proxys dont le chemin est défini pour que les services récupèrent les données du backend.

Model.js- Il contient les objets qui lient les données du magasin à afficher. Il a le mappage des objets de données backend vers la vue dataIndex. Les données sont récupérées à l'aide de store.

Utils.js- Il n'est pas inclus dans l'architecture MVC mais constitue une bonne pratique à utiliser pour rendre le code propre, moins complexe et plus lisible. Nous pouvons écrire des méthodes dans ce fichier et les appeler dans le contrôleur ou le moteur de rendu de vue si nécessaire. Il est également utile à des fins de réutilisation du code.

Dans l'architecture MVVM, le contrôleur est remplacé par ViewModel.

ViewModel- Il médiatise essentiellement les changements entre la vue et le modèle. Il lie les données du modèle à la vue. En même temps, il n'a aucune interaction directe avec la vue. Il n'a connaissance que du modèle.

Comment ça fonctionne

Par exemple, si nous utilisons un objet modèle à deux ou trois endroits dans l'interface utilisateur. Si nous modifions la valeur à un endroit de l'interface utilisateur, nous pouvons voir sans même enregistrer ce changement. La valeur du modèle change et est donc reflétée à tous les endroits de l'interface utilisateur, partout où le modèle est utilisé.

Cela rend l'effort des développeurs beaucoup moins et plus facile car aucun codage supplémentaire n'est requis pour la liaison des données.

Ce chapitre répertorie les étapes pour écrire le premier programme Hello World dans Ext JS.

Étape 1

Créez une page index.htm dans l'éditeur de notre choix. Incluez les fichiers de bibliothèque requis dans la section head de la page html comme suit.

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>

Explication

  • La méthode Ext.onReady () sera appelée une fois que le JS Ext est prêt à rendre les éléments Ext JS.

  • La méthode Ext.create () est utilisée pour créer un objet dans Ext JS. Ici, nous créons un objet de classe de panneau simple Ext.Panel.

  • Ext.Panel est la classe prédéfinie dans Ext JS pour créer un panneau.

  • Chaque classe Ext JS a des propriétés différentes pour exécuter certaines fonctionnalités de base.

La classe Ext.Panel a diverses propriétés telles que -

  • renderToest l'élément sur lequel ce panneau doit être rendu. «helloWorldPanel» est l'ID div dans le fichier Index.html.

  • Height et width les propriétés permettent de personnaliser la taille du panneau.

  • Title la propriété est de fournir le titre au panneau.

  • Html property est le contenu html à afficher dans le panneau.

Étape 2

Ouvrez le fichier index.htm dans un navigateur standard et vous obtiendrez la sortie suivante sur le navigateur.

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.

Container in Ext JS est le composant dans lequel nous pouvons ajouter d'autres conteneurs ou composants enfants. Ces conteneurs peuvent avoir plusieurs dispositions pour organiser les composants dans les conteneurs. Nous pouvons ajouter ou supprimer les composants du conteneur et de ses éléments enfants. Ext.container.Container est la classe de base de tous les conteneurs dans Ext JS.

Sr. Non La description
1 Composants à l'intérieur du conteneur

Cet exemple montre comment définir les composants à l'intérieur d'un conteneur

2 Conteneur à l'intérieur du conteneur

Cet exemple montre comment définir un conteneur à l'intérieur d'un conteneur avec d'autres composants

Il existe différents types de conteneurs Ext.panel.Panel, Ext.form.Panel, Ext.tab.Panel et Ext.container.Viewport sont des conteneurs fréquemment utilisés dans Ext JS. Vous trouverez ci-dessous l'exemple qui montre comment utiliser ces conteneurs.

N ° Sr. Type de conteneurs et description
1 Panneau.ext.

Cet exemple montre un conteneur Ext.panel.Panel

2 Panneau de forme ext.

Cet exemple montre un conteneur Ext.form.Panel

3 Tableau ext.

Cet exemple montre un conteneur Ext.tab.Panel

4 Ext.container.Viewport

Cet exemple montre un conteneur Ext.container.Viewport

La mise en page est la façon dont les éléments sont disposés dans un conteneur. Il peut être horizontal, vertical ou tout autre. Ext JS a une mise en page différente définie dans sa bibliothèque, mais nous pouvons toujours écrire des mises en page personnalisées.

Sr. Non Disposition et description
1 Absolu

Cette disposition permet de positionner les éléments en utilisant les coordonnées XY dans le conteneur.

2 Accordéon

Cette disposition permet de placer tous les articles en pile (les uns sur les autres) à l'intérieur du conteneur.

3 Ancre

Cette disposition donne le privilège à l'utilisateur de spécifier la taille de chaque élément par rapport à la taille du conteneur.

4 Frontière

Dans cette disposition, divers panneaux sont imbriqués et séparés par des bordures.

5 Auto

Il s'agit de la mise en page par défaut qui décide de la mise en page des éléments en fonction du nombre d'éléments.

6 Carte (TabPanel)

Cette mise en page organise différents composants sous forme d'onglets. Les onglets seront affichés en haut du conteneur. Chaque fois qu'un seul onglet est visible et chaque onglet est considéré comme un composant différent.

sept Carte (assistant)

Dans cette disposition, chaque fois que les éléments viennent pour un espace de conteneur complet. Il existe une barre d'outils inférieure dans l'assistant de navigation.

8 Colonne

Cette disposition consiste à afficher plusieurs colonnes dans le conteneur. Nous pouvons définir une largeur fixe ou en pourcentage pour les colonnes. Le pourcentage de largeur sera calculé en fonction de la taille totale du conteneur.

9 En forme

Dans cette disposition, le conteneur est rempli d'un seul panneau. Lorsqu'il n'y a pas d'exigence spécifique liée à la mise en page, cette mise en page est utilisée.

dix Table

Comme son nom l'indique, cette mise en page organise les composants dans un conteneur au format de table HTML.

11 vBox

Cette disposition permet à l'élément d'être distribué de manière verticale. C'est l'une des mises en page les plus utilisées.

12 hBox

Cette disposition permet à l'élément d'être distribué de manière horizontale.

ExtJS UI est composé d'un ou plusieurs widgets appelés Composants. Ext Js a défini divers composants d'interface utilisateur qui peuvent être personnalisés selon vos besoins.

Sr. Non Méthodes et description
1 la grille

Le composant Grid peut être utilisé pour afficher les données dans un format tabulaire.

2 Forme

Le widget de formulaire consiste à obtenir les données de l'utilisateur.

3 Messagerie

La boîte de message est essentiellement utilisée pour afficher des données sous la forme d'une boîte d'alerte.

4 Graphique

Les graphiques sont utilisés pour représenter les données sous forme d'images.

5 Info-bulle

L'info-bulle est utilisée pour afficher des informations de base lorsqu'un événement se produit.

6 La fenêtre

Ce widget d'interface utilisateur sert à créer une fenêtre qui devrait apparaître lorsqu'un événement se produit.

sept Éditeur HTML

HTML Editor est l'un des composants d'interface utilisateur très utiles, qui est utilisé pour styliser les données que l'utilisateur entre en termes de polices, de couleur, de taille, etc.

8 Barre de progression

Affiche la progression du travail backend.

La fonction glisser-déposer est l'une des fonctionnalités puissantes ajoutées pour faciliter la tâche du développeur. Une opération de glissement, essentiellement, est un geste de clic sur un élément de l'interface utilisateur, tandis que le bouton de la souris est maintenu enfoncé et la souris est déplacée. Une opération de déplacement se produit lorsque le bouton de la souris est relâché après une opération de glissement.

Syntaxe

Ajout d'une classe glisser-déposer aux cibles déplaçables.

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

Ajout de la classe cible par glisser-déposer à la cible drappable.

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

Exemple

Voici un exemple simple.

<!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>

Le programme ci-dessus produira le résultat suivant -

À l'aide du glisser-déposer dans Extjs, nous pouvons déplacer les données d'une grille à l'autre et d'une grille à l'autre. Voici les exemples de déplacement de données entre des grilles et des formulaires.

Glisser-déposer - Grille à grille

glisser-déposer - Grille vers formulaire

Ext.js fournit un certain nombre de thèmes à utiliser dans vos applications. Vous pouvez ajouter un thème différent à la place d'un thème classique et voir la différence dans la sortie. Cela se fait simplement en remplaçant le fichier CSS du thème comme expliqué précédemment.

Thème Neptune

Considérez votre toute première application Hello World. Supprimez le CSS suivant de l'application.

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

Ajoutez le CSS suivant pour utiliser le thème Neptune.

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

Pour voir l'effet, essayez le programme suivant.

<!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>

Le programme ci-dessus produira le résultat suivant -

Thème Crisp

Considérez votre toute première application Hello World. Supprimez le CSS suivant de l'application.

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

Ajoutez le CSS suivant pour utiliser le thème Neptune.

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

Pour voir l'effet, essayez le programme suivant.

<!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>

Le programme ci-dessus produira le résultat suivant -

Thème Triton

Considérez votre toute première application Hello World. Supprimez le CSS suivant de l'application.

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

Ajoutez le CSS suivant pour utiliser le thème Triton.

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

Pour voir l'effet, essayez le programme suivant.

<!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>

Le programme ci-dessus produira le résultat suivant -

Thème gris

Considérez votre toute première application Hello World. Supprimez le CSS suivant de l'application.

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

Ajoutez le CSS suivant pour utiliser le thème Gray.

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

Pour voir l'effet, essayez le programme suivant.

<!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>

Le programme ci-dessus produira le résultat suivant -

Les événements sont quelque chose qui est déclenché lorsque quelque chose arrive à la classe. Par exemple, lorsqu'un bouton est cliqué ou avant / après le rendu de l'élément.

Méthodes d'écriture des événements

  • Événements intégrés utilisant des écouteurs
  • Joindre des événements plus tard
  • Événements personnalisés

Événements intégrés utilisant des écouteurs

Ext JS fournit une propriété d'écoute pour écrire des événements et des événements personnalisés dans des fichiers Ext JS.

Writing listener in Ext JS

Nous ajouterons l'auditeur dans le programme précédent lui-même en ajoutant une propriété listen au panneau.

<!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>

Le programme ci-dessus produira le résultat suivant -

De cette façon, nous pouvons également écrire plusieurs événements dans la propriété des écouteurs.

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>

Joindre un événement plus tard

Dans la méthode précédente d'écriture d'événements, nous avons écrit des événements dans les écouteurs au moment de la création des éléments. L'autre façon consiste à attacher des événements.

<!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>

Le programme ci-dessus produira le résultat suivant -

Événements personnalisés

Nous pouvons écrire des événements personnalisés dans Ext JS et déclencher les événements avec la méthode fireEvent. L'exemple suivant explique comment écrire des événements personnalisés.

<!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>

Une fois la page chargée et le document prêt, la page d'interface utilisateur avec un bouton apparaîtra et comme nous déclenchons un événement après 5 secondes, le document est prêt. La boîte d'alerte apparaîtra après 5 secondes.

Ici, nous avons écrit l'événement personnalisé 'myEvent' et nous déclenchons des événements en tant que button.fireEvent (eventName);

Le package de données est utilisé pour charger et enregistrer toutes les données dans l'application.

Le paquet de données a un grand nombre de classes mais les classes les plus importantes sont -

  • Model
  • Store
  • Proxy

Modèle

La classe de base du modèle est Ext.data.Model. Il représente une entité dans une application. Il lie les données du magasin à afficher. Il a le mappage des objets de données backend vers la vue dataIndex. Les données sont récupérées à l'aide de store.

Créer un modèle

Pour créer un modèle, nous devons étendre la classe Ext.data.Model et nous devons définir les champs, leur nom et le mappage.

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

Ici, le nom doit être le même que le dataIndex, que nous déclarons dans la vue et le mappage doit correspondre aux données, statiques ou dynamiques de la base de données, qui doivent être récupérées à l'aide de store.

Boutique

La classe de base du magasin est Ext.data.Store. Il contient les données mises en cache localement, qui doivent être rendues à la vue à l'aide d'objets de modèle. Store récupère les données à l'aide de proxys, dont le chemin est défini pour que les services récupèrent les données du backend.

Les données du magasin peuvent être récupérées de deux manières: statique ou dynamique.

Magasin statique

Pour le magasin statique, nous aurons toutes les données présentes dans le magasin, comme indiqué dans le code suivant.

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" }
   ];
});

Magasin dynamique

Les données dynamiques peuvent être récupérées à l'aide d'un proxy. Nous pouvons avoir un proxy qui peut récupérer des données depuis Ajax, Rest et Json.

Procuration

La classe de base du proxy est Ext.data.proxy.Proxy. Le proxy est utilisé par les modèles et les magasins pour gérer le chargement et l'enregistrement des données du modèle.

Il existe deux types de procurations

  • Proxy client
  • Proxy du serveur

Proxy client

Les proxys client incluent la mémoire et le stockage local utilisant le stockage local HTML5.

Proxy du serveur

Les serveurs proxy gèrent les données du serveur distant à l'aide d'Ajax, de données Json et du service 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 offre la possibilité d'utiliser différents packages de polices. Les packages de polices sont utilisés pour ajouter différentes classes pour les icônes disponibles dans le package.

  • Font-Awesome
  • Font-Pictos

Font-génial

Le nouveau thème ExtJS, Triton, a une famille de polices intégrée font-awesome incluse dans le framework lui-même, nous n'avons donc pas besoin d'exigence explicite pour la feuille de style font-awesome.

Voici un exemple d'utilisation des classes Font-Awesome dans le thème Triton.

Font-Awesome avec le thème Triton

Lorsque nous utilisons un autre thème en dehors de Triton, nous devons ou avons besoin d'ajouter une feuille de style pour font-awesome explicitement.

Voici un exemple d'utilisation des classes Font-Awesome sans le thème Triton.

Font-Awesome avec un thème normal (tout thème autre que le thème Triton)

Police-Pictos

Font-pictos n'est pas inclus dans le framework pour ExtJS, donc nous devons exiger la même chose. Seuls les utilisateurs licenciés de Sencha auront l'avantage d'utiliser font-pictos.

Étapes pour ajouter des polices-pictos

Step 1 - Exiger la classe font-pictos à l'aide de la commande suivante.

"requires": ["font-pictos"]

Step 2 - Ajoutez maintenant les classes pictos comme -

iconCls: 'pictos pictos-home'

Le style d'application fait référence à l'ajustement par l'utilisateur de l'aspect et de la convivialité des composants. Ces ajustements peuvent inclure: la couleur, les dégradés de couleurs, la police, les marges / remplissage, etc. Ext JS 6 a une nouvelle façon de styliser l'application.

Il utilise SCSS pour le style. SCSS est une manière plus dynamique d'écrire le code CSS. Nous pouvons écrire les variables dans notre feuille de style à l'aide de ceci. Cependant, un navigateur ne peut pas comprendre SCSS. Il ne peut comprendre que CSS, donc tous les fichiers SCSS doivent être compilés en CSS en un code prêt pour la production.

Ainsi, le fichier SCSS est appelé fichiers de préprocesseur. Dans Ext.js, la compilation se fait via l'outil Sencha CMD. Sencha CMD ne le compile manuellement qu'une seule fois à l'aide de la commande suivante.

sencha app build [development]

Global_CSS est le fichier CSS principal, auquel sont associées toutes les variables SCSS dans ExtJS qui peuvent être utilisées dans notre application pour personnaliser notre thème en fournissant une valeur différente en fonction de nos besoins.

Voici quelques-unes des variables CSS disponibles dans Global_CSS dans Ext.js.

Sr. Non Variable et description
1

$base-color

$ base-color: color (par exemple $ base-color: # 808080)

Cette couleur de base doit être utilisée dans tout le thème.

2

$base-gradient

$ base-gradient: string (par exemple $ base-gradient: 'matte')

Ce dégradé de base doit être utilisé dans tout le thème.

3

$body-background-color

$ body-background-color: couleur (par exemple $ body-background-color: # 808080)

Couleur d'arrière-plan à appliquer à l'élément du corps. S'il est défini sur transparent ou «aucun», aucun style de couleur d'arrière-plan ne sera défini sur l'élément de corps.

4

$color

$ color: color (par exemple $ color: # 808080)

Cette couleur de texte par défaut doit être utilisée dans tout le thème.

5

$font-family

$ font-family: string (par exemple $ font-family: arial)

Cette famille de polices par défaut doit être utilisée dans tout le thème.

6

$font-size

$ font-size: nombre (par exemple $ font-size: 9px)

Cette taille de police par défaut doit être utilisée dans tout le thème.

sept

$font-weight

$ font-weight: string / number (par exemple $ font-weight: normal)

Ce poids de police par défaut doit être utilisé dans tout le thème.

8

$font-weight-bold

$ font-weight-bold: string / number (par exemple $ font-weight-bold: bold)

Cette épaisseur de police par défaut pour la police en gras doit être utilisée dans tout le thème.

9

$include-chrome

$ include-chrome: boolean (par exemple $ include-chrome: true)

True pour inclure des règles spécifiques à Chrome.

dix

$include-ff

$ include-ff: booléen (par exemple $ include-ff: true)

True pour inclure des règles spécifiques à Firefox.

11

$include-ie

$ include-ie: booléen (par exemple $ include-ie: true)

True pour inclure les règles spécifiques d'Internet Explorer pour IE9 et versions antérieures.

12

$include-opera

$ include-opera: booléen (par exemple $ include-opera: true)

True pour inclure des règles spécifiques à Opera.

13

$include-safari

$ include-safari: booléen (par exemple $ include-safari: true)

True pour inclure des règles spécifiques à Opera.

14

$include-webkit

$ include-webkit: booléen (par exemple $ include-webkit: true)

True pour inclure des règles spécifiques à Webkit.

Le package de dessin dans ExtJS vous permet de dessiner des graphiques à usage général. Cela peut être utilisé pour les graphiques qui fonctionnent sur tous les navigateurs et appareils mobiles.

Sr. Non Dessin
1 Cercle

Ce graphique est utilisé pour créer une forme circulare.

2 Rectangle

Ce graphique est utilisé pour créer une forme rectangulaire.

3 Arc

Ce graphique est utilisé pour créer une forme d'arc.

4 Ellipse

Ce graphique est utilisé pour créer une forme d'ellipse.

5 EllipticalArc

Ce graphique est utilisé pour créer une forme d'arc elliptique.

6 Image

Ce graphique est utilisé pour ajouter une image à votre application.

sept Chemin

Ce graphique est utilisé pour créer un chemin libre.

8 Texte

Ce graphique est utilisé pour ajouter du texte à votre application.

9 Traduire après le rendu

Cette propriété est utilisée pour déplacer le point de départ dans votre conteneur, une fois le graphique rendu. Il peut être utilisé avec tous les graphiques.

dix Rotation

Cette propriété est utilisée pour ajouter une rotation au dessin ajouté. Il peut être utilisé avec tous les graphiques.

11 Carré

Ce graphique est utilisé pour créer un carré.

Il est toujours préférable de communiquer avec les utilisateurs dans la langue qu'ils comprennent et préfèrent. Le package de localisation Extjs prend en charge plus de 40 langues telles que l'allemand, le français, le coréen, le chinois, etc. Il est très simple d'implémenter les paramètres régionaux dans ExtJs. Vous trouverez tous les fichiers de paramètres régionaux fournis dans le dossier override du package ext-locale. Les fichiers de paramètres régionaux remplacent simplement ce qui indique à Ext JS de remplacer les valeurs anglaises par défaut de certains composants.

Le programme suivant est d'afficher le mois dans différents paramètres régionaux pour voir l'effet. Essayez le programme suivant.

<!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>

Le programme ci-dessus produira le résultat suivant

Pour utiliser des paramètres régionaux différents de l'anglais, nous aurions besoin d'ajouter le fichier spécifique aux paramètres régionaux dans notre programme. Ici, nous utilisons https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/localefr.js pour le français. Vous pouvez utiliser différents paramètres régionaux pour différentes langues telles que https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-ko.js pour le coréen, etc.

Le programme suivant consiste à afficher le sélecteur de date dans les paramètres régionaux coréens pour voir l'effet. Essayez le programme suivant.

<!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>

Le programme ci-dessus produira le résultat suivant -

Le tableau suivant répertorie les quelques paramètres régionaux disponibles dans ExtJS et l'URL de paramètres régionaux du fichier principal à modifier.

Lieu Langue URL des paramètres régionaux
ko coréen https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-ko.js
fr français https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-fa.js
es Espagnol https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-es.js
ja Japonais https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-ja.js
il italien https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-it.js
ru russe https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/locale-ru.js
zh_CN Simplifie le chinois https://cdnjs.cloudflare.com/ajax/libs/extjs/6.0.0/classic/locale/localezh_CN.js

En général, l'accessibilité signifie la disponibilité, le contenu est accessible signifie que le contenu est disponible.

En termes de logiciel, l'application est accessible signifie que l'application est disponible pour tous. Ici, tout signifie les personnes handicapées, les malvoyants ou ceux qui utilisent des lecteurs d'écran pour utiliser un ordinateur ou ceux qui préfèrent naviguer en utilisant le clavier au lieu d'utiliser une souris. navigation avec le clavier au lieu d'utiliser une souris.

Les applications accessibles sont appelées ARIA (Accessible Rich Internet Applications).

Accessibilité dans Ext JS

Ext JS est conçu pour garder cela à l'esprit qu'il doit fonctionner avec toutes les navigations au clavier. Il a une indexation d'onglet et une capacité de mise au point intégrées, et il est toujours activé par défaut, nous n'avons donc pas besoin d'ajouter de propriété pour activer cette fonctionnalité.

Cette fonctionnalité permet à tous les composants activés pour le clavier d'interagir avec l'utilisateur lorsqu'ils sont tabulés dans. Par exemple, nous pouvons utiliser tab pour passer au composant suivant au lieu d'une souris. De la même manière, nous pouvons utiliser shift + tab pour reculer et utiliser entrée sur le clavier pour cliquer, etc.

Style et onglets du focus

Le focus est intégré dans Extjs lors de l'utilisation de touches pour la tabulation.

L'exemple suivant montre comment le style change, lorsque le focus change avec les onglets.

<!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>

Pour voir l'effet, utilisez tab pour passer du bouton suivant et shft + tab pour se concentrer en arrière. Utilisez Entrée et voyez comment l'alerte associée au bouton ciblé apparaîtrait.

Thème ARIA

ExtJS fournit l'aria thématique pour les malvoyants.

L'exemple suivant montre le thème aria qui est facilement accessible pour les malvoyants.

<!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>

Le programme ci-dessus produira le résultat suivant. Vous pouvez utiliser les touches de tabulation et de souris haut et bas pour déplacer le focus sur la grille et le thème est essentiellement destiné aux personnes malvoyantes.

Tout code JavaScript peut être débogué à l'aide de alert() boîte ou console.log() ou avec le pointeur de débogage dans un débogueur.

Boîte d'alerte

Placez une boîte d'alerte dans le code à l'endroit où vous souhaitez vérifier le flux ou toute valeur de variable. Par exemple, alert ('message à afficher' + variable);

Outil de développement / débogage

Le débogueur est l'outil le plus important pour tout développeur pour vérifier le problème et l'erreur dans le code lors du développement.

Ext JS est un framework JavaScript, il peut donc être facilement débogué à l'aide d'outils de développement fournis par ou spécifiques à différents navigateurs. Tous les principaux navigateurs ont leurs outils de développement disponibles pour tester et déboguer le code JavaScript.

Les débogueurs populaires sont l'outil de développement IE pour IE, Firebug pour Firefox et l'outil de développement Chrome pour le navigateur Chrome.

Le débogueur Chrome est livré avec le navigateur Chrome, cependant, Firebug doit être installé spécifiquement car il ne vient pas en tant que package avec Firefox.

Voici un lien pour installer Firebug pour le navigateur Firefox http://getfirebug.com

Le raccourci pour ouvrir l'outil de développement dans le système d'exploitation Windows est la touche clavier F12.

Débogage du code JS dans le débogueur

Il existe deux façons de déboguer le code JavaScript.

  • La première façon, c'est de placer console.log() dans le code et voir la valeur du journal, qui sera imprimé dans la console de l'outil de développement.

  • La deuxième méthode consiste à utiliser des points d'arrêt dans l'outil de développement. Voici le processus.

    • Ouvrez le fichier dans tous les scripts disponibles sous la balise script.

    • Placez maintenant un point d'arrêt sur la ligne que vous souhaitez déboguer.

    • Exécutez l'application dans le navigateur.

    • Maintenant, chaque fois que le flux de code atteindra cette ligne, il cassera le code et y restera jusqu'à ce que l'utilisateur exécute le code avec les touches F6 (aller à la ligne suivante du code), F7 (entrer dans la fonction) ou F8 (aller au point d'arrêt suivant ou exécutez le code s'il n'y a plus de points d'arrêt) en fonction du flux que vous souhaitez déboguer.

    • Vous pouvez sélectionner la variable ou la fonction dont vous souhaitez voir la valeur.

    • Vous pouvez utiliser la console pour vérifier la valeur ou pour vérifier certaines modifications dans le navigateur lui-même.

Voici quelques fonctions intégrées, qui sont fortement utilisées dans Ext JS.

Classe Ext.is

Cette classe vérifie la plate-forme que vous utilisez, qu'il s'agisse d'un téléphone ou d'un ordinateur de bureau, d'un système d'exploitation Mac ou Windows. Voici les méthodes suivantes liées à la classe Ext.is.

Sr. Non Méthodes et description
1

Ext.is.Platforms

Cette fonction renvoie la plateforme disponible pour cette version.

Par exemple, lorsque vous exécutez la fonction suivante, elle renvoie quelque chose comme ceci -

[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

Cette fonction retournera true, si vous utilisez le système d'exploitation Android, sinon elle retourne false.

3

Ext.is.Desktop

Cette fonction retournera true, si vous utilisez un bureau pour l'application, sinon elle retourne false.

4

Ext.is.Phone

Cette fonction retournera true, si vous utilisez un mobile, sinon elle retourne false.

5

Ext.is.iPhone

Cette fonction retournera true si vous utilisez l'iPhone, sinon elle renvoie false.

6

Ext.is.iPod

Cette fonction retournera true, si vous utilisez un iPod, sinon elle retourne false.

sept

Ext.is.iPad

Cette fonction retournera true, si vous utilisez un iPad, sinon elle renvoie false.

8

Ext.is.Windows

Cette fonction retournera true, si vous utilisez le système d'exploitation Windows, sinon elle retourne false.

9

Ext.is.Linux

Cette fonction retournera true, si vous utilisez le système d'exploitation Linux, sinon elle retourne false.

dix

Ext.is.Blackberry

Cette fonction retournera true, si vous utilisez Blackberry, sinon elle retourne false.

11

Ext.is.Mac

Cette fonction retournera true, si vous utilisez le système d'exploitation Mac, sinon elle retourne false.

Classe de support ext.

Comme son nom l'indique, cette classe fournit des informations si la fonctionnalité est prise en charge par l'environnement actuel du navigateur / périphérique ou non.

Sr. Non Méthodes et description
1

Ext.supports.History

Il vérifie si l'appareil prend en charge l'historique HTML 5 comme window.history ou non. Si l'appareil prend en charge l'historique, il renvoietrue, sinon faux.

2

Ext.supports.GeoLocation

Il vérifie si l'appareil prend en charge la méthode de géolocalisation ou non. En interne, il vérifie la méthode navigator.geolocation.

3

Ext.supports.Svg

Il vérifie si le périphérique prend en charge la méthode des graphiques vectoriels évolutifs (svg) HTML 5. En interne, il recherche doc.createElementNS && !! doc.createElementNS ("http: /" + "/www.w3.org/2000/svg", "svg"). CreateSVGRect.

4

Ext.supports.Canvas

Il vérifie si l'appareil prend en charge le canevas de fonctionnalités HTML 5 pour dessiner la méthode ou non. En interne, il recherche doc.createElement ('canvas'). GetContext et renvoie une valeur basée sur la sortie de cette méthode.

5

Ext.supports.Range

Il vérifie si le navigateur prend en charge la méthode document.createRange ou non.

Classe Ext.String

La classe Ext.String a différentes méthodes pour travailler avec des données de chaîne. Les méthodes les plus utilisées sont le décodage d'encodage, le découpage, le basculement, l'urlAppend, etc.

Encoding Decoding function - Voici les fonctions disponibles dans la classe Ext.String pour encoder et décoder les valeurs HTML.

Sr. Non Méthodes et description
1

Ext.String.htmlEncode

Cette fonction est utilisée pour encoder la valeur html pour la rendre analysable.

Example -

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

Ext.String.htmlDecode

Cette fonction est utilisée pour décoder la valeur html encodée.

Example -

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

Ext.String.trim

Cette fonction est de couper l'espace indésirable dans la chaîne.

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

Ext.String.urlAppend

Cette méthode est utilisée pour ajouter une valeur dans la chaîne 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

Cette fonction permet de basculer les valeurs entre deux valeurs différentes.

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' );

Méthodes diverses

Sr. Non Méthodes et description
1

Ext.userAgent()

Cette fonction donne des informations sur le navigateur userAgent. UserAgent consiste à identifier le navigateur et le système d'exploitation sur le serveur Web.

Example - Si vous travaillez dans Mozilla, il renvoie quelque chose comme: "mozilla / 5.0 (windows nt 6.1; wow64; rv: 43.0) gecko / 20100101 firefox / 43.0"

2

Version related function

Cette fonction renvoie la version du navigateur actuellement utilisée, si la fonction est appelée liée à IE. Dans le navigateur Firefox, il renvoie 0. Ces fonctions sont Ext.firefoxVersion, Ext.ieVersion, etc.

Example - Si vous utilisez le navigateur Firefox et que vous appelez la méthode Ext.ieVersion pour récupérer la version d'IE, alors elle renvoie 0. Si vous utilisez la même méthode dans le navigateur IE, elle renverra la version que vous utilisez telle que 8 , 9, etc.

3

Ext.getVersion()

Cette fonction renvoie la version Ext JS en cours d'utilisation.

Example - Si vous appelez Ext.getVersion (), il renvoie un tableau de valeurs telles que version, version courte, etc.

Ext.getVersion (). Version renvoie la version actuelle d'Ext JS utilisée dans le programme, telle que «4.2.2».

4

Browser related functions

Ces fonctions renvoient des valeurs booléennes basées sur le navigateur utilisé. Ces méthodes sont Ext.isIE, Ext.isIE6, Ext.isFF06 et Ext.isChrome.

Example - Si vous utilisez un navigateur Chrome, la fonction Ext.isChrome retournera tout vrai, sinon elle retournera faux.

5

Ext.typeOf()

Cette fonction renvoie le type de données de la variable.

Example -

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

DataType related methods - Ces fonctions renvoient une valeur booléenne basée sur le type de données de la variable

Example -

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