Section courante

A propos

Section administrative du site

 Langage  Elément  Tutoriel  Programmation  Bibliothèque  Cadre d'application  API  SDK  Serveur  IDE  Aide 
ABAP/4
Ada
Assembleur
Assembly & bytecode
ASP (Active Server Pages)
Basic
C
C++
C# (C Sharp)
Cobol
ColdFusion
Fortran
HTML
Java
JavaScript
LISP
Logo
LotusScript
Oberon
Pascal
Perl
PHP
PL/1
Prolog
Python
Rebol
REXX
Ruby
SAS
NoSQL
SQL
Swift
X++ (Axapta)
GNAT
SMALLAda
VHDL
Assembleur 370
Assembleur 1802
Assembleur 4004
Assembleur 6502
Assembleur 6800
Assembleur 68000
Assembleur 8080 et 8085
Assembleur 8089
Assembleur 80x86
Assembleur AGC4
Assembleur ARM
Assembleur DPS 8000
Assembleur i860
Assembleur Itanium
Assembleur MIPS
Assembleur PDP-11
Assembleur PowerPC
Assembleur RISC-V
Assembleur SPARC
Assembleur SuperH
Assembleur UNIVAC I
Assembleur VAX
Assembleur Z80
Assembleur Z8000
Assembleur z/Architecture
ASSEMBLER/MONITOR 64
Micol Assembler
GFA Assembler
A86
MASM (Macro Assembler)
TASM (Turbo Assembler)
CIL
Jasmin
LLVM
MSIL
Parrot
P-Code (PCode)
SWEET16
G-Pascal
ASP 1.0
ASP 2.0
ASP 3.0
ASP.NET
ASP.NET Core
ABasiC (Amiga)
Adam SmartBASIC
Altair BASIC
AmigaBASIC (Amiga)
AMOS Basic (Amiga)
Atari Basic (Atari 400, 600 XL, 800, 800XL)
Basic Apple II (Integer BASIC/APPLESOFT)
Basic Commodore 64 (CBM-BASIC)
Basic Commodore 128 (BASIC 7.0)
Basic Commodore VIC-20 (CBM-BASIC 2.0)
Basic Coco 1 (Color Basic)
Basic Coco 2 (Extended Color Basic)
Basic Coco 3 (Extended Color Basic 2.0)
BASICA (PC DOS)
Basic Pro
BBC BASIC
Blitz BASIC (Amiga)
DarkBASIC
Dartmouth BASIC
GFA-Basic (Atari ST/Amiga)
GWBASIC (MS-DOS)
Liberty BASIC
Locomotive BASIC (Amstrad CPC)
MSX-Basic
Omikron Basic (Atari ST)
Oric Extended Basic
Power Basic
Quick Basic/QBasic (MS-DOS)
Sinclair BASIC (ZX80, ZX81, ZX Spectrum)
ST BASIC (Atari ST)
Turbo Basic
Vintage BASIC
VBScript
Visual Basic (VB)
Visual Basic .NET (VB .NET)
Visual Basic pour DOS
Yabasic
BeckerBASIC
SIMONS' BASIC
Basic09 d'OS-9
Disk Extended Color Basic
Basic09 d'OS-9
Disk Extended Color Basic
Access
Excel
Visual Basic pour Windows
Visual Basic .NET pour Windows
C Shell Unix (csh)
C pour Amiga
C pour Atari ST
C pour DOS
C pour Falcon030
C pour GEMDOS (Atari ST)
C pour Linux
C pour PowerTV OS
C pour OS/2
C pour Unix
C pour Windows
Aztec C
CoCo-C
GNU C
HiSoft C
IBM C/2
Introl-C
Lattice C
Microsoft C
MinGW C
MSX-C
Open Watcom C
OS-9 C Compiler
Pure C
Quick C
Turbo C
HiSoft C for Atari ST
HiSoft C for CP/M (Amstrad CPC)
C++ pour OS/2
C++ pour Windows
Borland C++
C++Builder
IBM VisualAge C++
Intel C++
MinGW C++
Open Watcom C++
Symantec C++
Turbo C++
Visual C++
Visual C++ .NET
Watcom C++
Zortech C++
C# (C Sharp) pour Windows
Apple III Cobol
Microsoft Cobol
BlueDragon
Lucee
OpenBD
Railo
Smith Project
Microsoft Fortran
WATFOR-77
CSS
FBML
Open Graph
SVG
XML
XSL/XSLT
LESS
SASS
GCJ (GNU)
JSP
Jython
Visual J++
Node.js
TypeScript
AutoLISP
ACSLogo
LotusScript pour Windows
Amiga Oberon
Oberon .NET
Apple Pascal
Delphi/Kylix/Lazarus
Free Pascal
GNU Pascal
HighSpeed Pascal
IBM Personal Computer Pascal
Lisa Pascal
Maxon Pascal
MPW Pascal
OS-9 Pascal
OSS Personal Pascal
Pascal-86
Pascal du Cray Research
Pascal/VS
Pascal-XT
PURE Pascal
QuickPascal
RemObjets Chrome
Sun Pascal
THINK Pascal
Tiny Pascal (TRS-80)
Turbo Pascal
UCSD Pascal
VAX Pascal
Virtual Pascal
Turbo Pascal for CP/M-80
Turbo Pascal for DOS
Turbo Pascal for Macintosh
Turbo Pascal for Windows
CodeIgniter (Cadre d'application)
Drupal (Projet)
Joomla! (Projet)
Phalanger (PHP .NET)
phpBB (Projet)
Smarty (balise)
Twig (balise)
Symfony (Cadre d'application)
WordPress (Projet)
Zend (Cadre d'application)
PL360
PL/M-80
PL/M-86
Turbo Prolog
CPython
IronPython
Jython
PyPy
AREXX
Regina REXX
JMP
Btrieve
Cassandra
Clipper
CouchDB
dBASE
Hbase
Hypertable
MongoDB
Redis
Access
BigQuery
DB2
H2
Interbase
MySQL
Oracle
PostgreSQL
SAP HANA
SQL Server
Sybase
U-SQL
Introduction
Les remarques
Les opérateurs
Les instructions conditionnelles
Les instructions de boucles
Les exceptions
Type de données élémentaire
Définition de fonction
Mots réservés
Référence de fonctions
Référence des classes
Référence des classes prédéfinies (objets prédéfinies)
Référence des classes de balises (objets de balises)
Les chaines de caractères
Débogage
Les opérations
Délai d'attente et minuterie
Bonjour
Affichage
Application
Astronomie
Biochimie
Chaine de caractères
Courriel
Finance
Formulaire
Géographie
Géométrie
Gouvernement
Jeux & stratégies
Mathématique
Médicale
Météorologie
Océanographie
Optimisation
Sport
Temps
Trigonométrie
Validation
Cercle
Calculatrice romaine
Phase lunaire
Calcul du calcium corrigé
Calcul le taux d'alcoolémie
Nombre réel avec un certain nombre de décimal
Majuscule (strtoupper ou UpperCase)
Minuscule (strtolower ou LowerCase)
Microsoft Outlook
Validation
Ajout de contact
IPaymt/Interet
NPer
PPaymt/Principal
«ComboBox» pour choisir une couleur
getRadioButtonValue
Soumettre un formulaire
Distance en Km entre deux longitudes et latitudes
Aire d'un cercle
Aire d'une surface de prisme rectangulaire
Aire d'un triangle
Distance entre deux points
Taxe de vente canadienne
Entrecroisés
Mot mystère
Ackermann
Division par 0
Exp
Factoriel
Fibonacci
Log
Nombre premier
Odd
Sqrt
Triangle Pascal
Valeur absolue
Hauteur utérine
Unité de mesure
Fréquence des vagues
AJAX
Hockey
Année bissextile
Date de la Pâque
Heure courante
FirstDayOfMonth
ACos/ArCos/ArcCos
ASin/ArcSin
Atn/ATan/ArcTan/ArcTangente
Cos/Cosinus
Sin/Sinus
Courriel
Extension de nom de domaine
ga.js
jQuery
LiveValidation
Lodash
Polymer
React (React.js)
TinyMCE
TinySort
jQuery Tools UI Library
Ample SDK
AngularJS
Bootstrap
Cypress
Ext JS
JEST
Mocha
Next.js
Prototype
React Native
Vue.js
Google Maps JavaScript API
WebGL
Bot Framework SDK
Facebook JavaScript SDK
Node.js
Komodo IDE
Visual Studio Code
Préface
Notes légal
Dictionnaire
Recherche

Introduction

L'AJAX, abréviation adopté par la communauté de «Asynchrone Javascript And Xml». Dans les modèles d'optimisation les plus intéressants des dernières années, l'AJAX est sans nulle doute la technique la plus intéressante. Toutefois, elle ne fonctionne pas avec tous les navigateurs, ce modèle est supporté par Internet Explorer avec l'Active X autorisé, Netscape, Firefox, Opera et Safari, mais lorsqu'on entre dans les navigateurs moins classique, comme par exemple sous DOS et ne supportant pas le JavaScript, alors cette technique devient impossible. En faite, on devrait dire que pour une application professionnel cette technique est crucial, mais pour un simple site informatif, la chose est beaucoup moins certaine.

L'idée dernière le AJAX c'est bien simple, effectuer un chargement d'un morceau de la page suite à une action ou un événement utilisateur.


Exemple d'une simpla chaine de caractères retourner en AJAX

Ecran de sortie

Le code présenté ici est inspiré d'à peu près tous les codes existant sur Internet, je n'ai pas réinventé la roue. Il est en deux morceaux, la page HTML contenant le code JavaScript et une fichier XML le plus simple possible. Voici enfin le petit code source permettant de produire cette effet :

  1. <script language="JavaScript" type="text/javascript">
  2. function makeRequest(URL,Caption) {
  3.  var RequeteHTTP=false;
  4.  if(window.XMLHttpRequest) { // Mozilla, Safari,...
  5.   RequeteHTTP = new XMLHttpRequest();
  6.   if(RequeteHTTP.overrideMimeType) RequeteHTTP.overrideMimeType('text/xml');
  7.  } else if(window.ActiveXObject) { // Internet Explorer
  8.   try {
  9.    RequeteHTTP = new ActiveXObject("Microsoft.XMLHTTP");
  10.   } catch (e) {
  11.    try {
  12.     RequeteHTTP = new ActiveXObject("Msxml2.XMLHTTP");
  13.    } catch (e) {}
  14.   }
  15.  }
  16.  if(RequeteHTTP) {
  17.   RequeteHTTP.onreadystatechange = function() { 
  18.    var DocumentXML = RequeteHTTP.responseXML;
  19.    try {
  20.     document.getElementById(Caption).innerHTML=DocumentXML.getElementsByTagName("root").item(0).firstChild.data;
  21.    } catch(e) {}
  22.   };
  23.   RequeteHTTP.open("GET", URL, true);
  24.   RequeteHTTP.send(null);
  25.  }
  26.   else 
  27.  alert("Opération annuler: Impossible de créer une instance XML par HTTP");
  28. }
  29. </script>
  30. <INPUT TYPE=BUTTON Value="Appellez la page XML" onclick="makeRequest('test.xml','spSortie')">
  31. <TABLE Border=1 BgColor="#000000" BorderColor="#000000" Width=100%><TR><TD>
  32. <FONT COLOR=White>
  33. <SPAN COLOR=White ID=spSortie>
  34. Ecran de sortie<BR>
  35. </SPAN>
  36. </FONT>
  37. </TD></TR></TABLE>

Et le code source «test.xml» charger lorsque vous appuyez sur le bouton :

<?xml version="1.0" ?>
<root>
Je suis un test.
</root>

Exemple de multiple chaîne de caractères retourner en AJAX

Dans cet exemple, nous utilisons deux fichiers XML contenu chacun une liste des provinces du Canada et une de la liste des Etats des Etats-Unis. Nous chargerons, les données de province ou d'état a chaque fois que l'utilisateur sélectionnera un pays différent. Voici, tout d'abord le fichier XML «canada.xml» :

<?xml version="1.0" encoding="ISO-8859-1"?>
<result>
<province>
<id>1</id>
<name>Alberta</name>
</province>
<province>
<id>2</id>
<name>Colombie Britannique</name>
</province>
<province>
<id>3</id>
<name>Ile-du-Prince-Édouard</name>
</province>
<province>
<id>4</id>
<name>Manitoba</name>
</province>
<province>
<id>5</id>
<name>Nouveau-Brunswick</name>
</province>
<province>
<id>6</id>
<name>Nouvelle-Écosse</name>
</province>
<province>
<id>7</id>
<name>Nunavut</name>
</province>
<province>
<id>8</id>
<name>Ontario</name>
</province>
<province>
<id>9</id>
<name>Québec</name>
</province>
<province>
<id>10</id>
<name>Saskatchewan</name>
</province>
<province>
<id>11</id>
<name>Terre-Neuve</name>
</province>
<province>
<id>12</id>
<name>Territoires du Nord Ouest</name>
</province>
<province>
<id>13</id>
<name>Yukon</name>
</province>
</result>

Voici, ensuite le fichier XML «usa.xml» :

<?xml version="1.0" encoding="ISO-8859-1"?>
<result>
<province>
<id>16</id>
<name>Alabama</name>
</province>
<province>
<id>17</id>
<name>Alaska</name>
</province>
<province>
<id>18</id>
<name>Arizona</name>
</province>
<province>
<id>19</id>
<name>Arkansas</name>
</province>
<province>
<id>20</id>
<name>Californie</name>
</province>
<province>
<id>21</id>
<name>Caroline du Nord</name>
</province>
<province>
<id>22</id>
<name>Caroline du Sud</name>
</province>
<province>
<id>23</id>
<name>Colorado</name>
</province>
<province>
<id>24</id>
<name>Connecticut</name>
</province>
<province>
<id>25</id>
<name>Dakota du Nord</name>
</province>
<province>
<id>26</id>
<name>Dakota du Sud</name>
</province>
<province>
<id>27</id>
<name>Delaware</name>
</province>
<province>
<id>81</id>
<name>Distric of Colombia</name>
</province>
<province>
<id>28</id>
<name>Floride</name>
</province>
<province>
<id>29</id>
<name>Georgie</name>
</province>
<province>
<id>30</id>
<name>Hawaii</name>
</province>
<province>
<id>31</id>
<name>Idaho</name>
</province>
<province>
<id>32</id>
<name>Illinois</name>
</province>
<province>
<id>33</id>
<name>Indiana</name>
</province>
<province>
<id>34</id>
<name>Iowa</name>
</province>
<province>
<id>35</id>
<name>Kansas</name>
</province>
<province>
<id>36</id>
<name>Kentucky</name>
</province>
<province>
<id>37</id>
<name>Louisiane</name>
</province>
<province>
<id>38</id>
<name>Maine</name>
</province>
<province>
<id>39</id>
<name>Maryland</name>
</province>
<province>
<id>40</id>
<name>Massachusetts</name>
</province>
<province>
<id>41</id>
<name>Michigan</name>
</province>
<province>
<id>42</id>
<name>Minnesota</name>
</province>
<province>
<id>43</id>
<name>Mississippi</name>
</province>
<province>
<id>44</id>
<name>Missouri</name>
</province>
<province>
<id>45</id>
<name>Montana</name>
</province>
<province>
<id>46</id>
<name>Nebraska</name>
</province>
<province>
<id>47</id>
<name>Nevada</name>
</province>
<province>
<id>48</id>
<name>New Hampshire</name>
</province>
<province>
<id>49</id>
<name>New Jersey</name>
</province>
<province>
<id>51</id>
<name>New York</name>
</province>
<province>
<id>77</id>
<name>North Las Vegas</name>
</province>
<province>
<id>50</id>
<name>Nouveau Mexique</name>
</province>
<province>
<id>52</id>
<name>Ohio</name>
</province>
<province>
<id>53</id>
<name>Oklahoma</name>
</province>
<province>
<id>54</id>
<name>Oregon</name>
</province>
<province>
<id>55</id>
<name>Pennsylvanie</name>
</province>
<province>
<id>56</id>
<name>Rhode Island</name>
</province>
<province>
<id>57</id>
<name>Tennessee</name>
</province>
<province>
<id>58</id>
<name>Texas</name>
</province>
<province>
<id>59</id>
<name>Utah</name>
</province>
<province>
<id>60</id>
<name>Vermont</name>
</province>
<province>
<id>61</id>
<name>Virginie</name>
</province>
<province>
<id>63</id>
<name>Virginie Occidentale</name>
</province>
<province>
<id>62</id>
<name>Washington</name>
</province>
<province>
<id>64</id>
<name>Wisconsin</name>
</province>
<province>
<id>65</id>
<name>Wyoming</name>
</province>
</result>

Voici finalement le code source JavaScript contenant le code AJAX :

  1. <form name="currEdit">
  2. <select name="pays" class="inputText" id="pays" style="width:310px;" onchange="updateThisProvince('pays','province');">
  3.      <option value="0">Sélectionner...</option>
  4.      <option value="8">Canada</option>
  5.      <option value="11">Etats-Unis</option>
  6. </select>
  7. <select name="province" class="inputText" id="province" style="width:310px;">
  8.      <option value="0">Sélectionner...</option>
  9. </select>
  10. </form>
  11. <script language="JavaScript" type="text/javascript">
  12.      function AddTagOption(list,valeur,texte) {
  13.              var option = document.createElement("OPTION");
  14.          option.value = valeur;
  15.          option.text  = texte;
  16.          list.options.add(option);
  17.      }
  18.  
  19.      function updateThisProvince(country_id,province_id) {
  20.           var country_id = document.getElementById(country_id).value; 
  21.           var list = document.getElementById(province_id);
  22.          var request; 
  23.           for(var i = list.options.length - 1; i > 0; i--) list.remove(i);
  24.           if (window.XMLHttpRequest) request = new XMLHttpRequest();
  25.          if (window.ActiveXObject) {
  26.              var names = [
  27.                  "Msxml2.XMLHTTP.6.0",
  28.                  "Msxml2.XMLHTTP.3.0",
  29.                  "Msxml2.XMLHTTP",
  30.                  "Microsoft.XMLHTTP"
  31.              ];
  32.              for(var i in names) {
  33.                  try{ request = new ActiveXObject(names[i]); }
  34.                  catch(e){}
  35.              }
  36.          }
  37.           switch(country_id) {
  38.                case "8":request.open('GET', "canada.xml", true);  break;
  39.                case "11":request.open('GET', "usa.xml", true);  break;
  40.                default:return;
  41.           }
  42.          request.onreadystatechange = function() {  
  43.            if (request.readyState == 4) {  
  44.               if(request.status == 200) {  
  45.                   response  = request.responseXML.documentElement;
  46.                   for(var I = 0; I < response.getElementsByTagName('id').length; I++) {
  47.                             AddTagOption(list,response.getElementsByTagName('id')[I].firstChild.data,response.getElementsByTagName('name')[I].firstChild.data);
  48.                   }
  49.                 }  
  50.               else  
  51.                 alert('Error', request.statusText);  
  52.            }  
  53.          };  
  54.          request.send(null);  
  55.      }
  56.      updateThisProvince('pays','province');
  57. </script>
  58.  

Le résultat de la technologie AJAX est le suivant :

Vous pourrez remplacer le fichier XML de cet exemple par un fichier générer en PHP, ASP ou Perl et faire une sélection en fonction de tous les pays, en utilisant cette technique.

Voir également

Articles - Optimisation pour des sites à haut niveau de trafic

PARTAGER CETTE PAGE SUR
Dernière mise à jour : Mercredi, le 5 octobre 2011