Ext.js - Données

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