HTML5 - Guide rapide

HTML5 est la prochaine révision majeure de la norme HTML remplaçant HTML 4.01, XHTML 1.0 et XHTML 1.1. HTML5 est une norme de structuration et de présentation de contenu sur le World Wide Web.

HTML5 est une coopération entre le World Wide Web Consortium (W3C) et le Web Hypertext Application Technology Working Group (WHATWG).

La nouvelle norme intègre des fonctionnalités telles que la lecture vidéo et le glisser-déposer qui dépendaient auparavant de plug-ins de navigateur tiers tels qu'Adobe Flash, Microsoft Silverlight et Google Gears.

Prise en charge du navigateur

Les dernières versions d'Apple Safari, Google Chrome, Mozilla Firefox et Opera prennent toutes en charge de nombreuses fonctionnalités HTML5 et Internet Explorer 9.0 prendra également en charge certaines fonctionnalités HTML5.

Les navigateurs Web mobiles préinstallés sur les iPhones, iPads et téléphones Android offrent tous une excellente prise en charge de HTML5.

Nouvelles fonctionnalités

HTML5 introduit un certain nombre de nouveaux éléments et attributs qui peuvent vous aider à créer des sites Web modernes. Voici un ensemble de certaines des fonctionnalités les plus importantes introduites dans HTML5.

  • New Semantic Elements - Ce sont comme <header>, <footer> et <section>.

  • Forms 2.0 - Améliorations des formulaires Web HTML où de nouveaux attributs ont été introduits pour la balise <input>.

  • Persistent Local Storage - A réaliser sans recourir à des plugins tiers.

  • WebSocket - Une technologie de communication bidirectionnelle de nouvelle génération pour les applications Web.

  • Server-Sent Events - HTML5 introduit les événements qui circulent du serveur Web aux navigateurs Web et ils sont appelés événements envoyés par le serveur (SSE).

  • Canvas - Cela prend en charge une surface de dessin bidimensionnelle que vous pouvez programmer avec JavaScript.

  • Audio & Video - Vous pouvez intégrer de l'audio ou de la vidéo sur vos pages Web sans recourir à des plugins tiers.

  • Geolocation - Les visiteurs peuvent désormais choisir de partager leur emplacement physique avec votre application Web.

  • Microdata - Cela vous permet de créer vos propres vocabulaires au-delà de HTML5 et d'étendre vos pages Web avec une sémantique personnalisée.

  • Drag and drop - Faites glisser et déposez les éléments d'un emplacement à un autre emplacement sur la même page Web.

Rétrocompatibilité

HTML5 est conçu, autant que possible, pour être rétrocompatible avec les navigateurs Web existants. Ses nouvelles fonctionnalités ont été construites sur des fonctionnalités existantes et vous permettent de fournir un contenu de secours pour les navigateurs plus anciens.

Il est suggéré de détecter la prise en charge de fonctionnalités HTML5 individuelles en utilisant quelques lignes de JavaScript.

Si vous ne connaissez aucune version précédente de HTML, je vous recommande de consulter notre HTML Tutorial avant d'explorer les fonctionnalités de HTML5.

Le langage HTML 5 possède une syntaxe HTML "personnalisée" compatible avec les documents HTML 4 et XHTML1 publiés sur le Web, mais non compatible avec les fonctionnalités SGML plus ésotériques de HTML 4.

HTML 5 n'a pas les mêmes règles de syntaxe que XHTML où nous avions besoin de noms de balises minuscules, citant nos attributs, un attribut devait avoir une valeur et fermer tous les éléments vides.

HTML5 est livré avec beaucoup de flexibilité et il prend en charge les fonctionnalités suivantes -

  • Noms de balises en majuscules.
  • Les citations sont facultatives pour les attributs.
  • Les valeurs d'attribut sont facultatives.
  • La fermeture des éléments vides est facultative.

Le DOCTYPE

Les DOCTYPE des anciennes versions de HTML étaient plus longs car le langage HTML était basé sur SGML et nécessitait donc une référence à une DTD.

Les auteurs HTML 5 utiliseraient une syntaxe simple pour spécifier DOCTYPE comme suit -

<!DOCTYPE html>

La syntaxe ci-dessus est insensible à la casse.

Encodage de caractère

Les auteurs HTML 5 peuvent utiliser une syntaxe simple pour spécifier le codage des caractères comme suit -

<meta charset = "UTF-8">

La syntaxe ci-dessus est insensible à la casse.

La balise <script>

Il est courant d'ajouter un attribut de type avec une valeur de "text / javascript" aux éléments de script comme suit -

<script type = "text/javascript" src = "scriptfile.js"></script>

HTML 5 supprime les informations supplémentaires requises et vous pouvez utiliser simplement la syntaxe suivante -

<script src = "scriptfile.js"></script>

La balise <link>

Jusqu'à présent, vous écriviez <link> comme suit -

<link rel = "stylesheet" type = "text/css" href = "stylefile.css">

HTML 5 supprime les informations supplémentaires requises et vous pouvez simplement utiliser la syntaxe suivante -

<link rel = "stylesheet" href = "stylefile.css">

Éléments HTML5

Les éléments HTML5 sont balisés à l'aide de balises de début et de balises de fin. Les balises sont délimitées à l'aide de chevrons avec le nom de balise entre les deux.

La différence entre les balises de début et de fin est que ces dernières incluent une barre oblique avant le nom de la balise.

Voici l'exemple d'un élément HTML5 -

<p>...</p>

Les noms de balises HTML5 sont insensibles à la casse et peuvent être écrits en majuscules ou en casse mixte, bien que la convention la plus courante soit de s'en tenir aux minuscules.

La plupart des éléments contiennent du contenu comme <p> ... </p> contient un paragraphe. Cependant, il est interdit à certains éléments de contenir du contenu et ceux-ci sont appelés éléments vides. Par exemple,br, hr, link, meta, etc.

Voici une liste complète des éléments HTML5 .

Attributs HTML5

Les éléments peuvent contenir des attributs qui sont utilisés pour définir diverses propriétés d'un élément.

Certains attributs sont définis globalement et peuvent être utilisés sur n'importe quel élément, tandis que d'autres sont définis pour des éléments spécifiques uniquement. Tous les attributs ont un nom et une valeur et ressemblent à ceux indiqués ci-dessous dans l'exemple.

Voici l'exemple d'un attribut HTML5 qui illustre comment baliser un élément div avec un attribut nommé class en utilisant une valeur de "exemple" -

<div class = "example">...</div>

Les attributs ne peuvent être spécifiés que dans les balises de début et ne doivent jamais être utilisés dans les balises de fin.

Les attributs HTML5 sont insensibles à la casse et peuvent être écrits en majuscules ou en casse mixte, bien que la convention la plus courante soit de s'en tenir aux minuscules.

Voici une liste complète des attributs HTML5 .

Document HTML5

Les balises suivantes ont été introduites pour une meilleure structure -

  • section- Cette balise représente un document générique ou une section d'application. Il peut être utilisé avec h1-h6 pour indiquer la structure du document.

  • article - Cette balise représente un élément indépendant du contenu d'un document, tel qu'une entrée de blog ou un article de journal.

  • aside - Cette balise représente un élément de contenu qui n'est que légèrement lié au reste de la page.

  • header - Cette balise représente l'en-tête d'une section.

  • footer - Cette balise représente un pied de page pour une section et peut contenir des informations sur l'auteur, des informations sur les droits d'auteur, et cetera.

  • nav - Cette balise représente une section du document destinée à la navigation.

  • dialog - Cette balise peut être utilisée pour marquer une conversation.

  • figure - Cette balise peut être utilisée pour associer une légende à un contenu intégré, tel qu'un graphique ou une vidéo.

Le balisage d'un document HTML 5 ressemblerait à ce qui suit -

<!DOCTYPE html> 

<html>  
   <head> 
      <meta charset = "utf-8"> 
      <title>...</title> 
   </head> 
  
   <body> 
      <header>...</header> 
      <nav>...</nav> 
      
      <article> 
         <section> 
            ... 
         </section> 
      </article> 
      <aside>...</aside> 
      
      <footer>...</footer> 
   </body> 
</html>
<!DOCTYPE html>  

<html>  
   <head> 
      <meta charset = "utf-8"> 
      <title>...</title> 
   </head> 
  
   <body> 
      <header role = "banner"> 
         <h1>HTML5 Document Structure Example</h1> 
         <p>This page should be tried in safari, chrome or Mozila.</p> 
      </header> 
   
      <nav> 
         <ul> 
            <li><a href = "https://www.tutorialspoint.com/html">HTML Tutorial</a></li> 
            <li><a href = "https://www.tutorialspoint.com/css">CSS Tutorial</a></li> 
            <li><a href = "https://www.tutorialspoint.com/javascript">
            JavaScript Tutorial</a></li> 
         </ul> 
      </nav> 
   
      <article> 
         <section> 
            <p>Once article can have multiple sections</p>
         </section> 
      </article> 
   
      <aside> 
         <p>This is  aside part of the web page</p> 
      </aside> 
   
      <footer> 
         <p>Created by <a href = "https://tutorialspoint.com/">Tutorials Point</a></p> 
      </footer> 
   
   </body> 
</html>

Il produira le résultat suivant -

Comme expliqué dans le chapitre précédent, les éléments peuvent contenir des attributs qui sont utilisés pour définir diverses propriétés d'un élément.

Certains attributs sont définis globalement et peuvent être utilisés sur n'importe quel élément, tandis que d'autres sont définis pour des éléments spécifiques uniquement. Tous les attributs ont un nom et une valeur et ressemblent à ceux indiqués ci-dessous dans l'exemple.

Voici l'exemple d'un attribut HTML5 qui illustre comment baliser un élément div avec un attribut nommé class en utilisant une valeur de "exemple" -

<div class = "example">...</div>

Les attributs ne peuvent être spécifiés que dans start tags et ne doit jamais être utilisé dans end tags.

Les attributs HTML5 sont insensibles à la casse et peuvent être écrits en majuscules ou en casse mixte, bien que la convention la plus courante soit de s'en tenir aux minuscules.

Attributs standard

Les attributs répertoriés ci-dessous sont pris en charge par presque toutes les balises HTML 5.

Attribut Options Fonction
clé d'accès Défini par l'utilisateur Spécifie un raccourci clavier pour accéder à un élément.
aligner droite, gauche, centre Aligne les balises horizontalement
Contexte URL Place une image d'arrière-plan derrière un élément
bgcolor valeurs numériques, hexadécimales, RVB Place une couleur d'arrière-plan derrière un élément
classe Défini par l'utilisateur Classifie un élément à utiliser avec les feuilles de style en cascade.
contenteditable vrai faux Spécifie si l'utilisateur peut modifier le contenu de l'élément ou non.
menu contextuel Identifiant du menu Spécifie le menu contextuel d'un élément.
data-XXXX Défini par l'utilisateur Attributs personnalisés. Les auteurs d'un document HTML peuvent définir leurs propres attributs. Doit commencer par "data-".
traînable vrai, faux, automatique Spécifie si un utilisateur est autorisé ou non à faire glisser un élément.
la taille Valeur numérique Spécifie la hauteur des tableaux, des images ou des cellules de tableau.
caché caché Spécifie si l'élément doit être visible ou non.
id Défini par l'utilisateur Nomme un élément à utiliser avec les feuilles de style en cascade.
article Liste des éléments Utilisé pour regrouper des éléments.
itemprop Liste d'objets Utilisé pour regrouper les éléments.
vérification orthographique vrai faux Spécifie si l'orthographe ou la grammaire de l'élément doit être vérifiée.
style Feuille de style CSS Spécifie un style en ligne pour un élément.
matière Identifiant défini par l'utilisateur Spécifie l'élément correspondant de l'élément.
tabindex Numéro de l'onglet Spécifie l'ordre de tabulation d'un élément.
Titre Défini par l'utilisateur Titre "Pop-up" pour vos éléments.
valigné haut, milieu, bas Aligne verticalement les balises dans un élément HTML.
largeur Valeur numérique Spécifie la largeur des tableaux, des images ou des cellules de tableau.

Pour une liste complète des balises HTML5 et des attributs associés, veuillez consulter notre référence aux balises HTML5 .

Attributs personnalisés

Une nouvelle fonctionnalité introduite dans HTML 5 est l'ajout d'attributs de données personnalisés.

Un attribut de données personnalisé commence par data-et serait nommé en fonction de vos besoins. Voici un exemple simple -

<div class = "example" data-subject = "physics" data-level = "complex">
   ...
</div>

Le code ci-dessus sera parfaitement valide HTML5 avec deux attributs personnalisés appelés datasubject et data-level . Vous pourrez obtenir les valeurs de ces attributs à l'aide d'API JavaScript ou CSS de la même manière que pour les attributs standard.

Lorsque les utilisateurs visitent votre site Web, ils effectuent diverses activités telles que cliquer sur du texte, des images et des liens, survoler des éléments définis, etc. Ce sont des exemples de ce que JavaScript appelle events.

Nous pouvons écrire nos gestionnaires d'événements en Javascript ou VBscript et vous pouvez spécifier ces gestionnaires d'événements comme valeur d'attribut de balise d'événement. La spécification HTML5 définit divers attributs d'événements comme indiqué ci-dessous -

Nous pouvons utiliser l'ensemble d'attributs suivant pour déclencher n'importe quel javascript ou vbscript code donné comme valeur, quand il y a un événement qui a lieu pour un élément HTML5.

Nous couvririons les événements spécifiques aux éléments tout en discutant de ces éléments en détail dans les chapitres suivants.

Attribut Valeur La description
hors ligne scénario Se déclenche lorsque le document est hors ligne
onabort scénario Déclenchements sur un événement d'abandon
sur la réimpression scénario Déclenchements après l'impression du document
onbeforeonload scénario Déclencheurs avant le chargement du document
onbeforeprint scénario Déclenchements avant l'impression du document
le flou scénario Se déclenche lorsque la fenêtre perd le focus
oncanplay scénario Déclenche lorsque le média peut démarrer la lecture, mais doit peut-être s'arrêter pour la mise en mémoire tampon
oncanplaythrough scénario Déclenche lorsque le contenu multimédia peut être lu jusqu'à la fin, sans s'arrêter pour la mise en mémoire tampon
sur le changement scénario Se déclenche lorsqu'un élément change
sur clic scénario Déclenchement par un clic de souris
oncontextmenu scénario Déclenchement lorsqu'un menu contextuel est déclenché
ondblclick scénario Déclenchement par un double-clic de souris
ondrag scénario Se déclenche lorsqu'un élément est déplacé
ondragend scénario Déclenchements à la fin d'une opération de glissement
ondragenter scénario Se déclenche lorsqu'un élément a été glissé vers une cible de dépôt valide
ondragleave scénario Se déclenche lorsqu'un élément quitte une cible de dépôt valide
ondragover scénario Se déclenche lorsqu'un élément est glissé sur une cible de dépôt valide
ondragstart scénario Se déclenche au début d'une opération de glissement
ondrop scénario Se déclenche lorsque l'élément glissé est déposé
ondurationchange scénario Se déclenche lorsque la longueur du support est modifiée
onemptied scénario Se déclenche lorsqu'un élément de ressource multimédia devient soudainement vide.
reporté scénario Se déclenche lorsque le média atteint la fin
onerror scénario Se déclenche lorsqu'une erreur se produit
onfocus scénario Se déclenche lorsque la fenêtre obtient le focus
onformchange scénario Se déclenche lorsqu'un formulaire change
onforminput scénario Se déclenche lorsqu'un formulaire reçoit une entrée utilisateur
onhaschange scénario Se déclenche lorsque le document a changé
en entrée scénario Se déclenche lorsqu'un élément reçoit une entrée utilisateur
oninvalid scénario Se déclenche lorsqu'un élément n'est pas valide
onkeydown scénario Se déclenche lorsqu'une touche est enfoncée
onkeypress scénario Se déclenche lorsqu'une touche est enfoncée et relâchée
onkeyup scénario Se déclenche lorsqu'une touche est relâchée
en charge scénario Se déclenche lors du chargement du document
onloadeddata scénario Se déclenche lorsque les données multimédias sont chargées
onloadedmetadata scénario Se déclenche lorsque la durée et d'autres données multimédias d'un élément multimédia sont chargées
onloadstart scénario Se déclenche lorsque le navigateur commence à charger les données multimédias
message scénario Se déclenche lorsque le message est déclenché
onmousedown scénario Se déclenche lorsqu'un bouton de la souris est enfoncé
à la souris scénario Se déclenche lorsque le pointeur de la souris se déplace
à la souris scénario Se déclenche lorsque le pointeur de la souris sort d'un élément
onmouseover scénario Se déclenche lorsque le pointeur de la souris se déplace sur un élément
onmouseup scénario Se déclenche lorsqu'un bouton de la souris est relâché
roue de secours scénario Se déclenche lors de la rotation de la molette de la souris
en ligne scénario Se déclenche lorsque le document est hors ligne
onoine scénario Se déclenche lorsque le document est mis en ligne
en ligne scénario Se déclenche lorsque le document est mis en ligne
onpagehide scénario Se déclenche lorsque la fenêtre est masquée
onpageshow scénario Se déclenche lorsque la fenêtre devient visible
en pause scénario Se déclenche lorsque les données multimédias sont mises en pause
onplay scénario Se déclenche lorsque la lecture des données multimédias va commencer
en cours de lecture scénario Se déclenche lorsque la lecture des données multimédias a commencé
onpopstate scénario Se déclenche lorsque l'historique de la fenêtre change
progresse scénario Se déclenche lorsque le navigateur récupère les données multimédias
onratechange scénario Se déclenche lorsque la vitesse de lecture des données multimédias a changé
onreadystatechange scénario Se déclenche lorsque l'état prêt change
onredo scénario Se déclenche lorsque le document effectue une restauration
onresize scénario Se déclenche lorsque la fenêtre est redimensionnée
onscroll scénario Se déclenche lorsque la barre de défilement d'un élément est en cours de défilement
à la recherche scénario Se déclenche lorsque l'attribut de recherche d'un élément multimédia n'est plus vrai et que la recherche est terminée
à la recherche scénario Se déclenche lorsque l'attribut de recherche d'un élément multimédia est vrai et que la recherche a commencé
onselect scénario Se déclenche lorsqu'un élément est sélectionné
installé scénario Se déclenche lorsqu'il y a une erreur lors de la récupération des données multimédias
au stockage scénario Se déclenche lors du chargement d'un document
onsubmit scénario Se déclenche lorsqu'un formulaire est soumis
mise en suspension scénario Se déclenche lorsque le navigateur a récupéré des données multimédias, mais s'est arrêté avant que l'intégralité du fichier multimédia ait été récupérée
à jour scénario Se déclenche lorsque le média change sa position de lecture
onundo scénario Se déclenche lorsqu'un document effectue une annulation
en déchargement scénario Se déclenche lorsque l'utilisateur quitte le document
onvolumechange scénario Se déclenche lorsque le média modifie le volume, également lorsque le volume est réglé sur "muet"
en attente scénario Se déclenche lorsque la lecture du contenu multimédia a cessé, mais devrait reprendre

Web Forms 2.0 est une extension des fonctionnalités de formulaires présentes dans HTML4. Les éléments de formulaire et les attributs en HTML5 fournissent un plus grand degré de balisage sémantique que HTML4 et nous libèrent de beaucoup de scripts et de styles fastidieux qui étaient requis dans HTML4.

L'élément <input> en HTML4

Les éléments d'entrée HTML4 utilisent le type attribut pour spécifier le type de données.HTML4 fournit les types suivants -

N ° Sr. Type et description
1

text

Un champ de texte de forme libre, nominalement exempt de sauts de ligne.

2

password

Un champ de texte de forme libre pour les informations sensibles, nominalement exempt de sauts de ligne.

3

checkbox

Un ensemble de zéro ou plusieurs valeurs à partir d'une liste prédéfinie.

4

radio

Une valeur énumérée.

5

submit

Un formulaire gratuit de bouton lance la soumission du formulaire.

6

file

Un fichier arbitraire avec un type MIME et éventuellement un nom de fichier.

sept

image

Une coordonnée, relative à la taille d'une image particulière, avec la sémantique supplémentaire qu'elle doit être la dernière valeur sélectionnée et lance la soumission du formulaire.

8

hidden

Une chaîne arbitraire qui n'est normalement pas affichée à l'utilisateur.

9

select

Une valeur énumérée, un peu comme le type de radio.

dix

textarea

Un champ de texte de forme libre, nominalement sans restrictions de saut de ligne.

11

button

Une forme libre de bouton qui peut déclencher tout événement lié au bouton.

Voici un exemple simple d'utilisation d'étiquettes, de boutons radio et de boutons d'envoi -

... 
<form action = "http://example.com/cgiscript.pl" method = "post">  
   <p> 
      <label for = "firstname">first name: </label> 
      <input type = "text" id = "firstname"><br /> 
   
      <label for = "lastname">last name: </label> 
      <input type = "text" id = "lastname"><br /> 
   
      <label for = "email">email: </label> 
      <input type = "text" id = "email"><br> 
   
      <input type = "radio" name = "sex" value = "male"> Male<br> 
      <input type = "radio" name = "sex" value = "female"> Female<br> 
      <input type = "submit" value = "send"> <input type = "reset"> 
   </p> 
</form> 
 ...

L'élément <input> en HTML5

Outre les attributs mentionnés ci-dessus, les éléments d'entrée HTML5 ont introduit plusieurs nouvelles valeurs pour le typeattribut. Ceux-ci sont énumérés ci-dessous.

NOTE - Essayez tous les exemples suivants en utilisant la dernière version de Opera navigateur.

N ° Sr. Type et description
1 datetime

Une date et une heure (année, mois, jour, heure, minute, seconde, fractions de seconde) codées selon ISO 8601 avec le fuseau horaire défini sur UTC.

2 datetime-local

Une date et une heure (année, mois, jour, heure, minute, seconde, fractions de seconde) encodées selon ISO 8601, sans informations de fuseau horaire.

3 Date

Une date (année, mois, jour) encodée selon ISO 8601.

4 mois

Une date composée d'une année et d'un mois codée selon ISO 8601.

5 la semaine

Une date composée d'une année et d'un numéro de semaine codés selon ISO 8601.

6 temps

Une heure (heure, minute, seconde, fraction de seconde) codée selon ISO 8601.

sept nombre

Il n'accepte que la valeur numérique. L'attribut step spécifie la précision, par défaut à 1.

8 intervalle

Le type de plage est utilisé pour les champs d'entrée qui doivent contenir une valeur d'une plage de nombres.

9 email

Il n'accepte que la valeur e-mail. Ce type est utilisé pour les champs de saisie qui doivent contenir une adresse e-mail. Si vous essayez d'envoyer un texte simple, cela oblige à saisir uniquement l'adresse e-mail au format [email protected].

dix URL

Il n'accepte que la valeur URL. Ce type est utilisé pour les champs de saisie qui doivent contenir une adresse URL. Si vous essayez d'envoyer un texte simple, cela oblige à entrer uniquement l'adresse URL soit au format http://www.example.com soit au format http://example.com.

L'élément <output>

HTML5 a introduit un nouvel élément <output> qui est utilisé pour représenter le résultat de différents types de sortie, comme la sortie écrite par un script.

Vous pouvez utiliser le forattribut pour spécifier une relation entre l'élément de sortie et d'autres éléments du document qui ont affecté le calcul (par exemple, en tant qu'entrées ou paramètres). La valeur de l'attribut for est une liste d'ID d'autres éléments séparés par des espaces.

<!DOCTYPE HTML>

<html>
   <head>
      <script type = "text/javascript">
         
         function showResult() {
            x = document.forms["myform"]["newinput"].value;
            document.forms["myform"]["result"].value = x;
         }
      </script>
   </head>
   
   <body>

      <form action = "/cgi-bin/html5.cgi" method = "get" name = "myform">
         Enter a value : <input type = "text" name = "newinput" />
         <input type = "button" value = "Result"  onclick = "showResult();" />
         <output name = "result"></output>
      </form>
		
   </body>
</html>

Il produira le résultat suivant -

L'attribut d'espace réservé

HTML5 a introduit un nouvel attribut appelé placeholder. Cet attribut sur les éléments <input> et <textarea> fournit une indication à l'utilisateur de ce qui peut être saisi dans le champ. Le texte de l'espace réservé ne doit pas contenir de retours chariot ni de sauts de ligne.

Voici la syntaxe simple pour l'attribut d'espace réservé -

<input type = "text" name = "search" placeholder = "search the web"/>

Cet attribut est uniquement pris en charge par les dernières versions des navigateurs Mozilla, Safari et Crome.

<!DOCTYPE HTML>

<html>
   <body>

      <form action = "/cgi-bin/html5.cgi" method = "get">
         Enter email : <input type = "email" name = "newinput" 
            placeholder = "[email protected]"/>
         <input type = "submit" value = "submit" />
      </form>

   </body>
</html>

Cela produira le résultat suivant -

L'attribut autofocus

Il s'agit d'un modèle simple en une étape, facilement programmé en JavaScript au moment du chargement du document, qui concentre automatiquement un champ de formulaire particulier.

HTML5 a introduit un nouvel attribut appelé autofocus qui serait utilisé comme suit -

<input type = "text" name = "search" autofocus/>

Cet attribut est uniquement pris en charge par les dernières versions des navigateurs Mozilla, Safari et Chrome.

<!DOCTYPE HTML>

<html>
   <body>
   
      <form action = "/cgi-bin/html5.cgi" method = "get">
         Enter email : <input type = "text" name = "newinput" autofocus/>
         <p>Try to submit using Submit button</p>
         <input type = "submit" value = "submit" />
      </form>
      
   </body>
</html>

L'attribut requis

Désormais, vous n'avez pas besoin d'avoir JavaScript pour les validations côté client, car une zone de texte vide ne serait jamais soumise car HTML5 a introduit un nouvel attribut appelé required qui serait utilisé comme suit et insisterait pour avoir une valeur -

<input type = "text" name = "search" required/>

Cet attribut est uniquement pris en charge par les dernières versions des navigateurs Mozilla, Safari et Chrome.

<!DOCTYPE HTML>

<html>
   <body>
   
      <form action = "/cgi-bin/html5.cgi" method = "get">
         Enter email : <input type = "text" name = "newinput" required/>
         <p>Try to submit using Submit button</p>
         <input type = "submit" value = "submit" />
      </form>
      
   </body>
</html>

Il produira le résultat suivant -

SVG signifie Scalable Vector Graphics et c'est un langage pour décrire les graphiques 2D et les applications graphiques en XML et le XML est ensuite rendu par un visualiseur SVG.

SVG est surtout utile pour les diagrammes de type vectoriel tels que les diagrammes à secteurs, les graphiques bidimensionnels dans un système de coordonnées X, Y, etc.

SVG est devenu une recommandation du W3C le 14 janvier 2003 et vous pouvez vérifier la dernière version de la spécification SVG dans Spécification SVG .

Affichage des fichiers SVG

La plupart des navigateurs Web peuvent afficher SVG comme ils peuvent afficher PNG, GIF et JPG. Les utilisateurs d'Internet Explorer devront peut-être installer Adobe SVG Viewer pour pouvoir afficher SVG dans le navigateur.

Incorporer SVG dans HTML5

HTML5 permet d'incorporer directement SVG en utilisant <svg>...</svg> balise qui a la syntaxe simple suivante -

<svg xmlns = "http://www.w3.org/2000/svg">
   ...    
</svg>

Firefox 3.7 a également introduit une option de configuration ("about: config") où vous pouvez activer HTML5 en suivant les étapes suivantes -

  • Type about:config dans votre barre d'adresse Firefox.

  • Cliquez sur "Je ferai attention, je le promets!" sur le message d'avertissement qui apparaît (et assurez-vous de le respecter!).

  • Type html5.enable dans la barre de filtre en haut de la page.

  • Actuellement, il serait désactivé, alors cliquez dessus pour basculer la valeur sur true.

Votre analyseur Firefox HTML5 devrait maintenant être activé et vous devriez pouvoir expérimenter avec les exemples suivants.

HTML5 - Cercle SVG

Voici la version HTML5 d'un exemple SVG qui dessinerait un cercle en utilisant la balise <circle> -

<!DOCTYPE html>

<html>
   <head>
   
      <style>
         #svgelem {
            position: relative;
            left: 50%;
            -webkit-transform: translateX(-20%);
            -ms-transform: translateX(-20%);
            transform: translateX(-20%);
         }
      </style>
      <title>SVG</title>
      <meta charset = "utf-8" />
   </head>
   
   <body>
      <h2 align = "center">HTML5 SVG Circle</h2>
		
      <svg id = "svgelem" height = "200" xmlns = "http://www.w3.org/2000/svg">
         <circle id = "redcircle" cx = "50" cy = "50" r = "50" fill = "red" />
      </svg>
   </body>
</html>

Cela produirait le résultat suivant dans la dernière version de Firefox compatible HTML5.

HTML5 - Rectangle SVG

Voici la version HTML5 d'un exemple SVG qui dessinerait un rectangle en utilisant la balise <rect> -

<!DOCTYPE html>

<html>
   <head>
   
      <style>
         #svgelem {
            position: relative;
            left: 50%;
            -webkit-transform: translateX(-50%);
            -ms-transform: translateX(-50%);
            transform: translateX(-50%);
         }
      </style>
      <title>SVG</title>
      <meta charset = "utf-8" />
   </head>
   
   <body>
      <h2 align = "center">HTML5 SVG Rectangle</h2>
      
      <svg id = "svgelem" height = "200" xmlns = "http://www.w3.org/2000/svg">
         <rect id = "redrect" width = "300" height = "100" fill = "red" />
      </svg>
   </body>
</html>

Cela produirait le résultat suivant dans la dernière version de Firefox compatible HTML5.

HTML5 - Ligne SVG

Voici la version HTML5 d'un exemple SVG qui dessinerait une ligne en utilisant la balise <line> -

<!DOCTYPE html>

<html>
   <head>
      
      <style>
         #svgelem {
            position: relative;
            left: 50%;
            -webkit-transform: translateX(-50%);
            -ms-transform: translateX(-50%);
            transform: translateX(-50%);
         }
      </style>
      <title>SVG</title>
      <meta charset = "utf-8" />
   </head>
   
   <body>
      <h2 align = "center">HTML5 SVG Line</h2>
      
      <svg id = "svgelem" height = "200" xmlns = "http://www.w3.org/2000/svg">
         <line x1 = "0" y1 = "0" x2 = "200" y2 = "100" 
            style = "stroke:red;stroke-width:2"/>
      </svg>
   </body>
</html>

Vous pouvez utiliser le style attribut qui vous permet de définir des informations de style supplémentaires telles que les couleurs de trait et de remplissage, la largeur du trait, etc.

Cela produirait le résultat suivant dans la dernière version de Firefox compatible HTML5.

HTML5 - Ellipse SVG

Voici la version HTML5 d'un exemple SVG qui dessinerait une ellipse en utilisant la balise <ellipse> -

<!DOCTYPE html>

<html>
   <head>
      
      <style>
         #svgelem {
            position: relative;
            left: 50%;
            -webkit-transform: translateX(-40%);
            -ms-transform: translateX(-40%);
            transform: translateX(-40%);
         }
      </style>
      <title>SVG</title>
      <meta charset = "utf-8" />
   </head>
	
   <body>
      <h2 align = "center">HTML5 SVG Ellipse</h2>
      
      <svg id = "svgelem" height = "200" xmlns = "http://www.w3.org/2000/svg">
         <ellipse cx = "100" cy = "50" rx = "100" ry = "50" fill = "red" />
      </svg>
		
   </body>
</html>

Cela produirait le résultat suivant dans la dernière version de Firefox compatible HTML5.

HTML5 - Polygone SVG

Voici la version HTML5 d'un exemple SVG qui dessinerait un polygone en utilisant la balise <polygon> -

<!DOCTYPE html>

<html>
   <head>
   
      <style>
         #svgelem {
            position: relative;
            left: 50%;
            -webkit-transform: translateX(-50%);
            -ms-transform: translateX(-50%);
            transform: translateX(-50%);
         }
      </style>
      <title>SVG</title>
      <meta charset = "utf-8" />
   </head>
	
   <body>
      <h2 align = "center">HTML5 SVG Polygon</h2>
      
      <svg id = "svgelem" height = "200" xmlns = "http://www.w3.org/2000/svg">
         <polygon  points = "20,10 300,20, 170,50" fill = "red" />
      </svg>
   </body>
</html>

Cela produirait le résultat suivant dans la dernière version de Firefox compatible HTML5.

HTML5 - Polyligne SVG

Voici la version HTML5 d'un exemple SVG qui dessinerait une polyligne en utilisant la balise <polyline> -

<!DOCTYPE html>

<html>
   <head>
      
      <style>
         #svgelem {
            position: relative;
            left: 50%;
            -webkit-transform: translateX(-20%);
            -ms-transform: translateX(-20%);
            transform: translateX(-20%);
         }
      </style>
      <title>SVG</title>
      <meta charset = "utf-8" />
   </head>
	
   <body>
      <h2 align = "center">HTML5 SVG Polyline</h2>
      <svg id = "svgelem" height = "200" xmlns = "http://www.w3.org/2000/svg">
         <polyline points = "0,0 0,20 20,20 20,40 40,40 40,60" fill = "red" />
      </svg>
   </body>
</html>

Cela produirait le résultat suivant dans la dernière version de Firefox compatible HTML5.

HTML5 - Dégradés SVG

Voici la version HTML5 d'un exemple SVG qui dessinerait une ellipse en utilisant la balise <ellipse> et utiliserait la balise <radialGradient> pour définir un dégradé radial SVG.

De même, vous pouvez utiliser la balise <linearGradient> pour créer un dégradé linéaire SVG.

<!DOCTYPE html>

<html>
   <head>
      
      <style>
         #svgelem {
            position: relative;
            left: 50%;
            -webkit-transform: translateX(-40%);
            -ms-transform: translateX(-40%);
            transform: translateX(-40%);
         }
      </style>
      <title>SVG</title>
      <meta charset = "utf-8" />
   </head>
	
   <body>
      <h2 align = "center">HTML5 SVG Gradient Ellipse</h2>
      
      <svg id = "svgelem" height = "200" xmlns = "http://www.w3.org/2000/svg">
         <defs>
            <radialGradient id="gradient" cx = "50%" cy = "50%" r = "50%" fx = "50%" 
               fy = "50%">
               <stop offset = "0%" style = "stop-color:rgb(200,200,200); stop-opacity:0"/>
               <stop offset = "100%" style = "stop-color:rgb(0,0,255); stop-opacity:1"/>
            </radialGradient>
         </defs>
         <ellipse cx = "100" cy = "50" rx = "100" ry = "50" 
            style = "fill:url(#gradient)" />
      </svg>
		
   </body>
</html>

Cela produirait le résultat suivant dans la dernière version de Firefox compatible HTML5.

HTML5 - SVG Star

Voici la version HTML5 d'un exemple SVG qui dessinerait une étoile en utilisant la balise <polygon>.

<html>
   <head>
   
      <style>
         #svgelem {
            position: relative;
            left: 50%;
            -webkit-transform: translateX(-40%);
            -ms-transform: translateX(-40%);
            transform: translateX(-40%);
         }
      </style>
      <title>SVG</title>
      <meta charset = "utf-8" />
   </head>
   
   <body>	
      <h2 align = "center">HTML5 SVG Star</h2>
      
      <svg id = "svgelem" height = "200" xmlns = "http://www.w3.org/2000/svg">
         <polygon points = "100,10 40,180 190,60 10,60 160,180" fill = "red"/>
      </svg>
    </body>
</html>

Cela produirait le résultat suivant dans la dernière version de Firefox compatible HTML5.

La syntaxe HTML de HTML5 permet aux éléments MathML d'être utilisés dans un document en utilisant les balises <math> ... </math>.

La plupart des navigateurs Web peuvent afficher des balises MathML. Si votre navigateur ne prend pas en charge MathML, je vous suggère d'utiliser la dernière version de Firefox.

Exemples MathML

Voici un document HTML5 valide avec MathML -

<!doctype html>

<html>
   <head>
      <meta charset = "UTF-8">
      <title>Pythagorean theorem</title>
   </head>
	
   <body>
      <math xmlns = "http://www.w3.org/1998/Math/MathML">
		
         <mrow>
            <msup><mi>a</mi><mn>2</mn></msup>
            <mo>+</mo>
				
            <msup><mi>b</mi><mn>2</mn></msup>
            <mo> = </mo>
				
            <msup><mi>c</mi><mn>2</mn></msup>
         </mrow>
			
      </math>
   </body>
</html>

Cela produira le résultat suivant -

Utilisation de caractères MathML

Considérez, ce qui suit est le balisage qui utilise les caractères & InvisibleTimes; -

<!doctype html>

<html>
   <head>
      <meta charset = "UTF-8">
      <title>MathML Examples</title>
   </head>
	
   <body>
      <math xmlns = "http://www.w3.org/1998/Math/MathML">
		
         <mrow>			
            <mrow>
				
               <msup>
                  <mi>x</mi>
                  <mn>2</mn>
               </msup>
					
               <mo>+</mo>
					
               <mrow>
                  <mn>4</mn>
                  <mo>⁢</mo>
                  <mi>x</mi>
               </mrow>
					
               <mo>+</mo>
               <mn>4</mn>
					
            </mrow>
				
            <mo>=</mo>
            <mn>0</mn>
				 
         </mrow>
      </math>
   </body>
</html>

Cela produirait le résultat suivant. Si vous ne parvenez pas à voir un résultat correct comme x 2 + 4x + 4 = 0, utilisez Firefox 3.5 ou une version supérieure.

Cela produira le résultat suivant -

Exemples de présentation matricielle

Prenons l'exemple suivant qui serait utilisé pour représenter une simple matrice 2x2 -

<!doctype html>

<html>
   <head>
      <meta charset = "UTF-8">
      <title>MathML Examples</title>
   </head>
	
   <body>
      <math xmlns = "http://www.w3.org/1998/Math/MathML">
		
         <mrow>
            <mi>A</mi>
            <mo>=</mo>
			
            <mfenced open = "[" close="]">
			
               <mtable>
                  <mtr>
                     <mtd><mi>x</mi></mtd>
                     <mtd><mi>y</mi></mtd>
                  </mtr>
					
                  <mtr>
                     <mtd><mi>z</mi></mtd>
                     <mtd><mi>w</mi></mtd>
                  </mtr>
               </mtable>
               
            </mfenced>
         </mrow>
      </math>

   </body>
</html>

Cela produira le résultat suivant -

Cela produirait le résultat suivant. Si vous ne parvenez pas à voir le résultat approprié, utilisez Firefox 3.5 ou une version supérieure.

HTML5 introduit deux mécanismes, similaires aux cookies de session HTTP, pour stocker des données structurées côté client et pour surmonter les inconvénients suivants.

  • Des cookies sont inclus avec chaque requête HTTP, ralentissant ainsi votre application Web en transmettant les mêmes données.

  • Les cookies sont inclus avec chaque requête HTTP, envoyant ainsi des données non cryptées sur Internet.

  • Les cookies sont limités à environ 4 Ko de données. Pas assez pour stocker les données requises.

Les deux stockages sont session storage et local storage et ils seraient utilisés pour gérer différentes situations.

Les dernières versions de presque tous les navigateurs prennent en charge le stockage HTML5, y compris Internet Explorer.

Stockage de session

Le stockage de session est conçu pour les scénarios où l'utilisateur effectue une seule transaction, mais pourrait effectuer plusieurs transactions dans différentes fenêtres en même temps.

Exemple

Par exemple, si un utilisateur achète des billets d'avion dans deux fenêtres différentes, en utilisant le même site. Si le site utilisait des cookies pour garder une trace du ticket que l'utilisateur achetait, alors que l'utilisateur cliquait de page en page dans les deux fenêtres, le ticket en cours d'achat «fuirait» d'une fenêtre à l'autre, ce qui pourrait amener l'utilisateur à acheter deux billets pour le même vol sans vraiment s'en apercevoir.

HTML5 introduit l' attribut sessionStorage qui serait utilisé par les sites pour ajouter des données au stockage de session, et il sera accessible à n'importe quelle page du même site ouverte dans cette fenêtre, c'est-à-dire,session et dès que vous fermez la fenêtre, la session serait perdue.

Voici le code qui définirait une variable de session et accéderait à cette variable -

<!DOCTYPE HTML>

<html>
   <body>
      <script type = "text/javascript">
         
         if( sessionStorage.hits ) {
            sessionStorage.hits = Number(sessionStorage.hits) +1;
         } else {
            sessionStorage.hits = 1;
         }
         document.write("Total Hits :" + sessionStorage.hits );
      </script>
	
      <p>Refresh the page to increase number of hits.</p>
      <p>Close the window and open it again and check the result.</p>

   </body>
</html>

Cela produira le résultat suivant -

Stockage local

Le stockage local est conçu pour un stockage qui s'étend sur plusieurs fenêtres et dure au-delà de la session en cours. En particulier, les applications Web peuvent souhaiter stocker des mégaoctets de données utilisateur, telles que des documents entièrement créés par l'utilisateur ou la boîte aux lettres d'un utilisateur, côté client pour des raisons de performances.

Encore une fois, les cookies ne gèrent pas bien ce cas, car ils sont transmis à chaque demande.

Exemple

HTML5 introduit l' attribut localStorage qui serait utilisé pour accéder à la zone de stockage local d'une page sans limite de temps et ce stockage local sera disponible chaque fois que vous utiliserez cette page.

Voici le code qui définirait une variable de stockage local et accéderait à cette variable à chaque fois que cette page est accédée, même la prochaine fois, lorsque vous ouvrez la fenêtre -

<!DOCTYPE HTML>

<html>
   <body>
      <script type = "text/javascript">
         
         if( localStorage.hits ) {
            localStorage.hits = Number(localStorage.hits) +1;
         } else {
            localStorage.hits = 1;
         }
         document.write("Total Hits :" + localStorage.hits );
      </script>
		
      <p>Refresh the page to increase number of hits.</p>
      <p>Close the window and open it again and check the result.</p>

   </body>
</html>

Cela produira le résultat suivant -

Supprimer le stockage Web

Le stockage de données sensibles sur une machine locale peut être dangereux et laisser une faille de sécurité.

Les données de stockage de session seraient supprimées par les navigateurs immédiatement après la fin de la session.

Pour effacer un paramètre de stockage local, vous devez appeler localStorage.remove('key'); où «clé» est la clé de la valeur que vous souhaitez supprimer. Si vous souhaitez effacer tous les paramètres, vous devez appelerlocalStorage.clear() méthode.

Voici le code qui effacerait le stockage local complet -

<!DOCTYPE HTML>

<html>
   <body>

      <script type = "text/javascript">
         localStorage.clear();

         // Reset number of hits.
         if( localStorage.hits ) {
            localStorage.hits = Number(localStorage.hits) +1;
         } else {
            localStorage.hits = 1;
         }
         document.write("Total Hits :" + localStorage.hits );
			
      </script>
		
      <p>Refreshing the page would not to increase hit counter.</p>
      <p>Close the window and open it again and check the result.</p>

   </body>
</html>

Cela produira le résultat suivant -

L'API Web SQL Database ne fait pas partie de la spécification HTML5, mais il s'agit d'une spécification distincte qui introduit un ensemble d'API pour manipuler les bases de données côté client à l'aide de SQL.

Je suppose que vous êtes un grand développeur Web et si tel est le cas, vous connaissez sans aucun doute les concepts SQL et SGBDR. Si vous souhaitez toujours avoir une session avec SQL, vous pouvez suivre notre didacticiel SQL .

Web SQL Database fonctionnera dans la dernière version de Safari, Chrome et Opera.

Les méthodes de base

Il existe trois méthodes de base définies dans la spécification que je vais couvrir dans ce didacticiel -

  • openDatabase - Cette méthode crée l'objet de base de données en utilisant la base de données existante ou en en créant une nouvelle.

  • transaction - Cette méthode nous donne la possibilité de contrôler une transaction et d'effectuer une validation ou une annulation en fonction de la situation.

  • executeSql - Cette méthode est utilisée pour exécuter une requête SQL réelle.

Ouverture de la base de données

La méthode openDatabase se charge d'ouvrir une base de données si elle existe déjà, cette méthode la créera si elle n'existe pas déjà.

Pour créer et ouvrir une base de données, utilisez le code suivant -

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);

La méthode ci-dessus a pris les cinq paramètres suivants -

  • Nom de la base de données
  • Numéro de version
  • Description textuelle
  • Taille de la base de données
  • Rappel de création

Le dernier et le 5e argument, le rappel de création sera appelé si la base de données est en cours de création. Sans cette fonctionnalité, cependant, les bases de données sont toujours créées à la volée et correctement versionnées.

Exécuter des requêtes

Pour exécuter une requête, vous utilisez la fonction database.transaction (). Cette fonction a besoin d'un seul argument, qui est une fonction qui s'occupe d'exécuter réellement la requête comme suit -

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024); 

db.transaction(function (tx) {   
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)'); 
});

La requête ci-dessus créera une table appelée LOGS dans la base de données «mydb».

Opération INSERT

Pour créer des entrées dans la table, nous ajoutons une requête SQL simple dans l'exemple ci-dessus comme suit -

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024); 

db.transaction(function (tx) { 
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)'); 
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "foobar")'); 
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")'); 
});

Nous pouvons passer des valeurs dynamiques lors de la création en entrant comme suit -

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);  

db.transaction(function (tx) {   
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)'); 
   tx.executeSql('INSERT INTO LOGS (id,log) VALUES (?, ?'), [e_id, e_log]; 
});

Ici e_id et e_log sont des variables externes, et executeSql mappe chaque élément de l'argument du tableau aux "?".

LIRE l'opération

Pour lire les enregistrements déjà existants, nous utilisons un rappel pour capturer les résultats comme suit -

var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024);  

db.transaction(function (tx) { 
   tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)');
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "foobar")'); 
   tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")'); 
});  

db.transaction(function (tx) { 
   tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) { 
      var len = results.rows.length, i; 
      msg = "<p>Found rows: " + len + "</p>"; 
      document.querySelector('#status').innerHTML +=  msg; 
  
      for (i = 0; i < len; i++) { 
         alert(results.rows.item(i).log ); 
      } 
  
   }, null); 
});

Exemple final

Alors enfin, gardons cet exemple dans un document HTML5 à part entière comme suit et essayons de l'exécuter avec le navigateur Safari.

<!DOCTYPE HTML> 

<html>  
   <head> 
  
      <script type = "text/javascript"> 
         var db = openDatabase('mydb', '1.0', 'Test DB', 2 * 1024 * 1024); 
         var msg; 
    
         db.transaction(function (tx) { 
            tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id unique, log)'); 
            tx.executeSql('INSERT INTO LOGS (id, log) VALUES (1, "foobar")'); 
            tx.executeSql('INSERT INTO LOGS (id, log) VALUES (2, "logmsg")'); 
            msg = '<p>Log message created and row inserted.</p>'; 
            document.querySelector('#status').innerHTML =  msg; 
         })

         db.transaction(function (tx) { 
            tx.executeSql('SELECT * FROM LOGS', [], function (tx, results) { 
               var len = results.rows.length, i; 
               msg = "<p>Found rows: " + len + "</p>"; 
               document.querySelector('#status').innerHTML +=  msg; 
      
               for (i = 0; i < len; i++) { 
                  msg = "<p><b>" + results.rows.item(i).log + "</b></p>"; 
                  document.querySelector('#status').innerHTML +=  msg; 
               } 
            }, null); 
         }); 
      </script> 
   </head> 
  
   <body> 
      <div id = "status" name = "status">Status Message</div> 
   </body> 
</html>

Cela produira le résultat suivant -

Les applications Web conventionnelles génèrent des événements qui sont envoyés au serveur Web. Par exemple, un simple clic sur un lien demande une nouvelle page au serveur.

Le type d'événements qui circulent du navigateur Web au serveur Web peut être appelé événements envoyés par le client.

Avec HTML5, WHATWG Web Applications 1.0 introduit des événements qui circulent du serveur Web aux navigateurs Web et ils sont appelés événements envoyés par le serveur (SSE). En utilisant SSE, vous pouvez envoyer des événements DOM en continu de votre serveur Web au navigateur du visiteur.

L'approche de streaming d'événements ouvre une connexion permanente au serveur, envoyant des données au client lorsque de nouvelles informations sont disponibles, éliminant ainsi le besoin d'interrogation continue.

Les événements envoyés par le serveur standardisent la façon dont nous diffusons les données du serveur vers le client.

Application Web pour SSE

Pour utiliser les événements envoyés par le serveur dans une application Web, vous devez ajouter un élément <eventsource> au document.

le src L'attribut de l'élément <eventsource> doit pointer vers une URL qui doit fournir une connexion HTTP persistante qui envoie un flux de données contenant les événements.

L'URL pointerait vers un script PHP, PERL ou tout autre script Python qui se chargerait d'envoyer les données d'événements de manière cohérente. Voici un exemple simple d'application Web qui s'attendrait à l'heure du serveur.

<!DOCTYPE HTML>

<html>
   <head>
   
      <script type = "text/javascript">
         /* Define event handling logic here */
      </script>
   </head>
   
   <body>
      <div id = "sse">
         <eventsource src = "/cgi-bin/ticker.cgi" />
      </div>
		
      <div id = "ticker">
         <TIME>
      </div>
   </body>
</html>

Script côté serveur pour SSE

Un script côté serveur doit envoyer Content-typeen-tête spécifiant le type text / event-stream comme suit.

print "Content-Type: text/event-stream\n\n";

Après avoir défini Content-Type, le script côté serveur enverrait un Event: balise suivie du nom de l'événement. L'exemple suivant enverrait Server-Time comme nom d'événement terminé par un caractère de nouvelle ligne.

print "Event: server-time\n";

La dernière étape consiste à envoyer les données d'événement en utilisant Data: balise qui serait suivie d'un entier de valeur de chaîne terminé par un caractère de nouvelle ligne comme suit -

$time = localtime();
print "Data: $time\n";

Enfin, voici le ticker.cgi complet écrit en Perl -

#!/usr/bin/perl  
print "Content-Type: text/event-stream\n\n";  

while(true) { 
   print "Event: server-time\n"; 
   $time = localtime(); 
   print "Data: $time\n"; 
   sleep(5); 
}

Gérer les événements envoyés par le serveur

Modifions notre application Web pour gérer les événements envoyés par le serveur. Voici le dernier exemple.

<!DOCTYPE HTML> 

<html>  
   <head> 
  
      <script type = "text/javascript"> 
         document.getElementsByTagName("eventsource")[0].addEventListener("server-time", 
         eventHandler, false); 
    
         function eventHandler(event) { 

            // Alert time sent by the server 
            document.querySelector('#ticker').innerHTML = event.data; 
         } 
      </script> 
   </head> 
  
   <body> 
      <div id = "sse"> 
         <eventsource src = "/cgi-bin/ticker.cgi" /> 
      </div> 
   
      <div id = "ticker" name = "ticker"> 
         [TIME] 
      </div> 
   </body> 
</html>

Avant de tester les événements envoyés par le serveur, je vous suggère de vous assurer que votre navigateur Web prend en charge ce concept.

WebSockets est une technologie de communication bidirectionnelle de nouvelle génération pour les applications Web qui fonctionne sur un seul socket et est exposée via une interface JavaScript dans les navigateurs compatibles HTML 5.

Une fois que vous avez établi une connexion Web Socket avec le serveur Web, vous pouvez envoyer des données du navigateur au serveur en appelant un send() méthode, et recevez des données du serveur au navigateur par un onmessage gestionnaire d'événements.

Voici l'API qui crée un nouvel objet WebSocket.

var Socket = new WebSocket(url, [protocal] );

Ici, le premier argument, url, spécifie l'URL à laquelle se connecter. Le deuxième attribut, protocole, est facultatif et, s'il est présent, spécifie un sous-protocole que le serveur doit prendre en charge pour que la connexion réussisse.

Attributs WebSocket

Voici l'attribut de l'objet WebSocket. En supposant que nous ayons créé l'objet Socket comme mentionné ci-dessus -

N ° Sr. Attribut et description
1

Socket.readyState

L'attribut readonly readyState représente l'état de la connexion. Il peut avoir les valeurs suivantes -

  • Une valeur de 0 indique que la connexion n'a pas encore été établie.

  • Une valeur de 1 indique que la connexion est établie et que la communication est possible.

  • Une valeur de 2 indique que la connexion est en cours de négociation de clôture.

  • Une valeur de 3 indique que la connexion a été fermée ou n'a pas pu être ouverte.

2

Socket.bufferedAmount

L'attribut en lecture seule bufferedAmount représente le nombre d'octets de texte UTF-8 qui ont été mis en file d'attente à l'aide de la méthode send ().

Événements WebSocket

Voici les événements associés à l'objet WebSocket. En supposant que nous ayons créé l'objet Socket comme mentionné ci-dessus -

un événement Gestionnaire d'événements La description
ouvert Socket.onopen Cet événement se produit lorsque la connexion socket est établie.
message Socket.onmessage Cet événement se produit lorsque le client reçoit des données du serveur.
Erreur Socket.onerror Cet événement se produit en cas d'erreur de communication.
Fermer Socket.onclose Cet événement se produit lorsque la connexion est fermée.

Méthodes WebSocket

Voici les méthodes associées à l'objet WebSocket. En supposant que nous ayons créé l'objet Socket comme mentionné ci-dessus -

N ° Sr. Méthode et description
1

Socket.send()

La méthode d'envoi (données) transmet les données à l'aide de la connexion.

2

Socket.close()

La méthode close () serait utilisée pour mettre fin à toute connexion existante.

Exemple WebSocket

Un WebSocket est une socket TCP bidirectionnelle standard entre le client et le serveur. Le socket démarre comme une connexion HTTP, puis "Mises à niveau" vers un socket TCP après une prise de contact HTTP. Après la poignée de main, chaque côté peut envoyer des données.

Code HTML et JavaScript côté client

Au moment de la rédaction de ce didacticiel, seuls quelques navigateurs Web prennent en charge l'interface WebSocket (). Vous pouvez essayer l'exemple suivant avec la dernière version de Chrome, Mozilla, Opera et Safari.

<!DOCTYPE HTML>

<html>
   <head>
      
      <script type = "text/javascript">
         function WebSocketTest() {
            
            if ("WebSocket" in window) {
               alert("WebSocket is supported by your Browser!");
               
               // Let us open a web socket
               var ws = new WebSocket("ws://localhost:9998/echo");
				
               ws.onopen = function() {
                  
                  // Web Socket is connected, send data using send()
                  ws.send("Message to send");
                  alert("Message is sent...");
               };
				
               ws.onmessage = function (evt) { 
                  var received_msg = evt.data;
                  alert("Message is received...");
               };
				
               ws.onclose = function() { 
                  
                  // websocket is closed.
                  alert("Connection is closed..."); 
               };
            } else {
              
               // The browser doesn't support WebSocket
               alert("WebSocket NOT supported by your Browser!");
            }
         }
      </script>
		
   </head>
   
   <body>
      <div id = "sse">
         <a href = "javascript:WebSocketTest()">Run WebSocket</a>
      </div>
      
   </body>
</html>

Installez pywebsocket

Avant de tester le programme client ci-dessus, vous avez besoin d'un serveur prenant en charge WebSocket. Téléchargez mod_pywebsocket-xxxtar.gz depuis pywebsocket qui vise à fournir une extension Web Socket pour Apache HTTP Server et installez-le en suivant ces étapes.

  • Décompressez et décompressez le fichier téléchargé.

  • Aller à l'intérieur pywebsocket-x.x.x/src/ annuaire.

  • Construction de $ python setup.py

  • installation de $ sudo python setup.py

  • Ensuite, lisez le document par -

    • $ pydoc mod_pywebsocket

Cela l'installera dans votre environnement python.

Démarrez le serveur

Aller au pywebsocket-x.x.x/src/mod_pywebsocket dossier et exécutez la commande suivante -

$sudo python standalone.py -p 9998 -w ../example/

Cela lancera l'écoute du serveur sur le port 9998 et utilisera le handlers répertoire spécifié par l'option -w où réside notre echo_wsh.py.

Maintenant, en utilisant le navigateur Chrome, ouvrez le fichier html que vous avez créé au début. Si votre navigateur prend en charge WebSocket (), alors vous obtiendrez une alerte indiquant que votre navigateur prend en charge WebSocket et enfin lorsque vous cliquez sur "Exécuter WebSocket", vous obtiendrez un message d'au revoir envoyé par le script du serveur.

L'élément HTML5 <canvas> vous offre un moyen simple et puissant de dessiner des graphiques à l'aide de JavaScript. Il peut être utilisé pour dessiner des graphiques, créer des compositions photo ou faire des animations simples (et pas si simples).

Voici un élément <canvas> simple qui n'a que deux attributs spécifiques width et height plus tous les attributs HTML5 de base tels que l'identifiant, le nom et la classe, etc.

<canvas id = "mycanvas" width = "100" height = "100"></canvas>

Vous pouvez facilement trouver cet élément <canvas> dans le DOM en utilisant la méthode getElementById () comme suit -

var canvas = document.getElementById("mycanvas");

Voyons un exemple simple d'utilisation de l'élément <canvas> dans un document HTML5.

<!DOCTYPE HTML>

<html>
   <head>
   
      <style>
         #mycanvas{border:1px solid red;}
      </style>
   </head>
   
   <body>
      <canvas id = "mycanvas" width = "100" height = "100"></canvas>
   </body>
</html>

Cela produira le résultat suivant -

Le contexte de rendu

Le <canvas> est initialement vide, et pour afficher quelque chose, un script doit d'abord accéder au contexte de rendu et dessiner dessus.

L'élément canvas a une méthode DOM appelée getContext, utilisé pour obtenir le contexte de rendu et ses fonctions de dessin. Cette fonction prend un paramètre, le type de contexte2d.

Voici le code pour obtenir le contexte requis avec une vérification si votre navigateur prend en charge l'élément <canvas> -

var canvas  = document.getElementById("mycanvas");

if (canvas.getContext) {   
   var ctx = canvas.getContext('2d');   
   // drawing code here   
} else {   
   
   // canvas-unsupported code here 
}

Prise en charge du navigateur

Les dernières versions de Firefox, Safari, Chrome et Opera prennent toutes en charge HTML5 Canvas, mais IE8 ne prend pas en charge nativement la toile.

Vous pouvez utiliser ExplorerCanvas pour prendre en charge le canevas via Internet Explorer. Il vous suffit d'inclure ce JavaScript comme suit -

<!--[if IE]><script src = "excanvas.js"></script><![endif]-->

Exemples de canevas HTML5

Ce didacticiel couvre les exemples suivants liés à l'élément HTML5 <canvas>.

N ° Sr. Exemples et description
1 Dessin de rectangles

Apprenez à dessiner un rectangle à l'aide de l'élément <canvas> HTML5

2 Tracés de dessin

Apprenez à créer des formes à l'aide de chemins dans l'élément <canvas> HTML5

3 Dessin de lignes

Apprenez à dessiner des lignes à l'aide de l'élément <canvas> HTML5

4 Dessin Bézier

Apprenez à dessiner une courbe de Bézier à l'aide de l'élément <canvas> HTML5

5 Dessin Quadratique

Apprenez à dessiner une courbe quadratique à l'aide de l'élément <canvas> HTML5

6 Utilisation d'images

Apprenez à utiliser des images avec l'élément HTML5 <canvas>

sept Créer des dégradés

Apprenez à créer des dégradés à l'aide de l'élément <canvas> HTML5

8 Styles et couleurs

Apprenez à appliquer des styles et des couleurs à l'aide de l'élément <canvas> HTML5

9 Texte et polices

Apprenez à dessiner un texte incroyable en utilisant différentes polices et leur taille.

dix Motif et ombre

Apprenez à dessiner différents motifs et ombres portées.

11 États du canevas

Découvrez comment enregistrer et restaurer les états du canevas tout en réalisant des dessins complexes sur un canevas.

12 Traduction de canevas

Cette méthode est utilisée pour déplacer le canevas et son origine vers un autre point de la grille.

13 Rotation de la toile

Cette méthode est utilisée pour faire pivoter le canevas autour de l'origine actuelle.

14 Mise à l'échelle de la toile

Cette méthode est utilisée pour augmenter ou diminuer les unités dans une grille de canevas.

15 Transformation de la toile

Ces méthodes permettent de modifier directement la matrice de transformation.

16 Composition de la toile

Cette méthode est utilisée pour masquer certaines zones ou effacer des sections du canevas.

17 Animation sur toile

Apprenez à créer une animation de base à l'aide du canevas HTML5 et de JavaScript.

Les fonctionnalités HTML5 incluent la prise en charge native de l'audio et de la vidéo sans avoir besoin de Flash.

Les balises HTML5 <audio> et <video> simplifient l'ajout de médias à un site Web. Vous devez définirsrc attribut pour identifier la source multimédia et inclure un attribut de contrôle afin que l'utilisateur puisse lire et mettre en pause le support.

Vidéo intégrée

Voici la forme la plus simple d'intégration d'un fichier vidéo dans votre page Web -

<video src = "foo.mp4"  width = "300" height = "200" controls>
   Your browser does not support the <video> element.   
</video>

Le projet de spécification HTML5 actuel ne spécifie pas les formats vidéo que les navigateurs doivent prendre en charge dans la balise vidéo. Mais les formats vidéo les plus couramment utilisés sont -

  • Ogg - Fichiers Ogg avec codec vidéo Thedora et codec audio Vorbis.

  • mpeg4 - Fichiers MPEG4 avec codec vidéo H.264 et codec audio AAC.

Vous pouvez utiliser la balise <source> pour spécifier le média avec le type de média et de nombreux autres attributs. Un élément vidéo autorise plusieurs éléments sources et le navigateur utilisera le premier format reconnu -

<!DOCTYPE HTML>

<html>
   <body>
      
      <video  width = "300" height = "200" controls autoplay>
         <source src = "/html5/foo.ogg" type ="video/ogg" />
         <source src = "/html5/foo.mp4" type = "video/mp4" />
         Your browser does not support the <video> element.
      </video>
      
   </body>
</html>

Cela produira le résultat suivant -

Spécification des attributs vidéo

La balise vidéo HTML5 peut avoir un certain nombre d'attributs pour contrôler l'aspect et la convivialité et diverses fonctionnalités du contrôle -

N ° Sr. Attribut et description
1

autoplay

Cet attribut booléen, s'il est spécifié, la lecture de la vidéo commencera automatiquement dès qu'elle le pourra sans s'arrêter pour terminer le chargement des données.

2

autobuffer

Cet attribut booléen, s'il est spécifié, la vidéo commencera automatiquement la mise en mémoire tampon même si elle n'est pas configurée pour être lue automatiquement.

3

controls

Si cet attribut est présent, il permettra à l'utilisateur de contrôler la lecture vidéo, y compris le volume, la recherche et la pause / reprise de la lecture.

4

height

Cet attribut spécifie la hauteur de la zone d'affichage de la vidéo, en pixels CSS.

5

loop

Cet attribut booléen, s'il est spécifié, permettra à la vidéo de rechercher automatiquement le début après avoir atteint la fin.

6

preload

Cet attribut spécifie que la vidéo sera chargée au chargement de la page et prête à être diffusée. Ignoré si la lecture automatique est présente.

sept

poster

Il s'agit de l'URL d'une image à afficher jusqu'à ce que l'utilisateur joue ou cherche.

8

src

L'URL de la vidéo à intégrer. Ceci est facultatif; vous pouvez à la place utiliser l'élément <source> dans le bloc vidéo pour spécifier la vidéo à intégrer.

9

width

Cet attribut spécifie la largeur de la zone d'affichage de la vidéo, en pixels CSS.

Intégration audio

HTML5 prend en charge la balise <audio> qui est utilisée pour incorporer du contenu audio dans un document HTML ou XHTML comme suit.

<audio src = "foo.wav" controls autoplay>
   Your browser does not support the <audio> element.   
</audio>

Le projet de spécification HTML5 actuel ne spécifie pas les formats audio que les navigateurs doivent prendre en charge dans la balise audio. Mais les formats audio les plus couramment utilisés sontogg, mp3 et wav.

Vous pouvez utiliser <source & ggt; balise pour spécifier le média avec le type de média et de nombreux autres attributs. Un élément audio autorise plusieurs éléments sources et le navigateur utilisera le premier format reconnu -

<!DOCTYPE HTML>

<html>
   <body>
      
      <audio controls autoplay>
         <source src = "/html5/audio.ogg" type = "audio/ogg" />
         <source src = "/html5/audio.wav" type = "audio/wav" />
         Your browser does not support the <audio> element.
      </audio>
      
   </body>
</html>

Cela produira le résultat suivant -

Spécification d'attribut audio

La balise audio HTML5 peut avoir un certain nombre d'attributs pour contrôler l'apparence et les diverses fonctionnalités du contrôle -

N ° Sr. Attribut et description
1

autoplay

Cet attribut booléen s'il est spécifié, l'audio commencera automatiquement à être lu dès qu'il le pourra sans s'arrêter pour terminer le chargement des données.

2

autobuffer

Cet attribut booléen s'il est spécifié, l'audio commencera automatiquement la mise en mémoire tampon même s'il n'est pas configuré pour être lu automatiquement.

3

controls

Si cet attribut est présent, il permettra à l'utilisateur de contrôler la lecture audio, y compris le volume, la recherche et la pause / reprise de la lecture.

4

loop

Cet attribut booléen, s'il est spécifié, permettra à l'audio de rechercher automatiquement le début après avoir atteint la fin.

5

preload

Cet attribut spécifie que l'audio sera chargé au chargement de la page et prêt à être exécuté. Ignoré si la lecture automatique est présente.

6

src

L'URL de l'audio à intégrer. Ceci est facultatif; vous pouvez à la place utiliser l'élément <source> dans le bloc vidéo pour spécifier la vidéo à intégrer.

Gestion des événements médiatiques

La balise audio et vidéo HTML5 peut avoir un certain nombre d'attributs pour contrôler diverses fonctionnalités du contrôle à l'aide de JavaScript -

S.No. Description de l'évenement
1

abort

Cet événement est généré lorsque la lecture est interrompue.

2

canplay

Cet événement est généré lorsque suffisamment de données sont disponibles pour que le média puisse être lu.

3

ended

Cet événement est généré lorsque la lecture est terminée.

4

error

Cet événement est généré lorsqu'une erreur se produit.

5

loadeddata

Cet événement est généré lorsque la première image du support a fini de se charger.

6

loadstart

Cet événement est généré lorsque le chargement du média commence.

sept

pause

Cet événement est généré lorsque la lecture est en pause.

8

play

Cet événement est généré lorsque la lecture démarre ou reprend.

9

progress

Cet événement est généré périodiquement pour informer de la progression du téléchargement du média.

dix

ratechange

Cet événement est généré lorsque la vitesse de lecture change.

11

seeked

Cet événement est généré lorsqu'une opération de recherche se termine.

12

seeking

Cet événement est généré lorsqu'une opération de recherche commence.

13

suspend

Cet événement est généré lorsque le chargement du support est suspendu.

14

volumechange

Cet événement est généré lorsque le volume audio change.

15

waiting

Cet événement est généré lorsque l'opération demandée (telle que la lecture) est retardée en attendant la fin d'une autre opération (telle qu'une recherche).

Voici l'exemple qui permet de lire la vidéo donnée -

<!DOCTYPE HTML>

<html>
   <head>
   
      <script type = "text/javascript">
         function PlayVideo() {
            var v = document.getElementsByTagName("video")[0];  
            v.play(); 
         }
      </script>
   </head>
   
   <body>
   
      <form>         
         <video width = "300" height = "200" src = "/html5/foo.mp4">
         Your browser does not support the video element.
         </video>
         <br />
         <input type = "button" onclick = "PlayVideo();" value = "Play"/>
      </form>
      
   </body>
</html>

Cela produira le résultat suivant -

Configuration des serveurs pour le type de média

La plupart des serveurs ne servent pas par défaut les médias Ogg ou mp4 avec les types MIME corrects, vous devrez donc probablement ajouter la configuration appropriée pour cela.

AddType audio/ogg .oga
AddType audio/wav .wav
AddType video/ogg .ogv .ogg
AddType video/mp4 .mp4

L'API de géolocalisation HTML5 vous permet de partager votre position avec vos sites Web préférés. Un JavaScript peut capturer votre latitude et votre longitude et peut être envoyé au serveur Web principal et effectuer des tâches sophistiquées tenant compte de l'emplacement, comme trouver des entreprises locales ou afficher votre emplacement sur une carte.

Aujourd'hui, la plupart des navigateurs et appareils mobiles prennent en charge l'API de géolocalisation. Les API de géolocalisation fonctionnent avec une nouvelle propriété de l'objet navigateur global ie. Objet de géolocalisation qui peut être créé comme suit -

var geolocation = navigator.geolocation;

L'objet de géolocalisation est un objet de service qui permet aux widgets de récupérer des informations sur l'emplacement géographique de l'appareil.

Méthodes de géolocalisation

L'objet de géolocalisation fournit les méthodes suivantes -

N ° Sr. Méthode et description
1 getCurrentPosition ()

Cette méthode récupère l'emplacement géographique actuel de l'utilisateur.

2 watchPosition ()

Cette méthode récupère des mises à jour périodiques sur l'emplacement géographique actuel de l'appareil.

3 clearWatch ()

Cette méthode annule un appel watchPosition en cours.

Exemple

Voici un exemple de code pour utiliser l'une des méthodes ci-dessus -

function getLocation() {
   var geolocation = navigator.geolocation;
   geolocation.getCurrentPosition(showLocation, errorHandler);
}

Ici, showLocation et errorHandler sont des méthodes de rappel qui seraient utilisées pour obtenir la position réelle comme expliqué dans la section suivante et pour gérer les erreurs s'il y en a.

Propriétés de l'emplacement

Les méthodes de géolocalisation getCurrentPosition () et getPositionUsingMethodName () spécifient la méthode de rappel qui récupère les informations d'emplacement. Ces méthodes sont appelées de manière asynchrone avec un objetPosition qui stocke les informations de localisation complètes.

le Positionobject spécifie l'emplacement géographique actuel de l'appareil. L'emplacement est exprimé sous la forme d'un ensemble de coordonnées géographiques avec des informations sur le cap et la vitesse.

Le tableau suivant décrit les propriétés de l'objet Position. Pour les propriétés facultatives, si le système ne peut pas fournir de valeur, la valeur de la propriété est définie sur null.

Propriété Type La description
coords objets Spécifie l'emplacement géographique de l'appareil. L'emplacement est exprimé sous la forme d'un ensemble de coordonnées géographiques avec des informations sur le cap et la vitesse.
coords.latitude Nombre Spécifie l'estimation de la latitude en degrés décimaux. La plage de valeurs est [-90,00, +90,00].
coords.longitude Nombre Spécifie l'estimation de la longitude en degrés décimaux. La plage de valeurs est [-180,00, +180,00].
coords.altitude Nombre [Facultatif] Spécifie l'estimation de l'altitude en mètres au-dessus de l'ellipsoïde WGS 84.
coords.accuracy Nombre [Facultatif] Spécifie la précision des estimations de latitude et de longitude en mètres.
coords.altitudeAccuracy Nombre [Facultatif] Spécifie la précision de l'estimation d'altitude en mètres.
coords.heading Nombre [Facultatif] Spécifie la direction actuelle du mouvement de l'appareil en degrés en comptant dans le sens des aiguilles d'une montre par rapport au nord géographique.
coords.speed Nombre [Facultatif] Spécifie la vitesse sol actuelle de l'appareil en mètres par seconde.
horodatage Date Spécifie l'heure à laquelle les informations d'emplacement ont été récupérées et l'objet Position créé.

Exemple

Voici un exemple de code qui utilise l'objet Position. Ici, la méthode showLocation est une méthode de rappel -

function showLocation( position ) {
   var latitude = position.coords.latitude;
   var longitude = position.coords.longitude;
   ...
}

Traitement des erreurs

La géolocalisation est compliquée et elle est indispensable pour détecter toute erreur et la gérer avec élégance.

Les méthodes de géolocalisation getCurrentPosition () et watchPosition () utilisent une méthode de rappel du gestionnaire d'erreurs qui donne PositionErrorobjet. Cet objet a les deux propriétés suivantes -

Propriété Type La description
code Nombre Contient un code numérique pour l'erreur.
message Chaîne Contient une description lisible par l'homme de l'erreur.

Le tableau suivant décrit les codes d'erreur possibles renvoyés dans l'objet PositionError.

Code Constant La description
0 ERREUR INCONNUE La méthode n'a pas réussi à récupérer l'emplacement du périphérique en raison d'une erreur inconnue.
1 PERMISSION REFUSÉE La méthode n'a pas réussi à récupérer l'emplacement de l'appareil car l'application n'a pas l'autorisation d'utiliser le service de localisation.
2 POSITION_UNAVAILABLE L'emplacement de l'appareil n'a pas pu être déterminé.
3 TEMPS LIBRE La méthode n'a pas pu récupérer les informations de localisation dans le délai d'expiration maximal spécifié.

Exemple

Voici un exemple de code qui utilise l'objet PositionError. Ici, la méthode errorHandler est une méthode de rappel -

function errorHandler( err ) {
   
   if (err.code == 1) {
      
      // access is denied
   }
   ...
}

Options de position

Voici la syntaxe réelle de la méthode getCurrentPosition () -

getCurrentPosition(callback, ErrorCallback, options)

Ici, le troisième argument est le PositionOptions objet qui spécifie un ensemble d'options pour récupérer l'emplacement géographique de l'appareil.

Voici les options qui peuvent être spécifiées comme troisième argument -

Propriété Type La description
enableHighAccuracy Booléen Spécifie si le widget souhaite recevoir l'estimation d'emplacement la plus précise possible. Par défaut, c'est faux.
temps libre Nombre La propriété timeout correspond au nombre de millisecondes que votre application Web est prête à attendre pour une position.
maximumAge Nombre Spécifie l'heure d'expiration en millisecondes des informations d'emplacement mises en cache.

Exemple

Voici un exemple de code qui montre comment utiliser les méthodes mentionnées ci-dessus -

function getLocation() {
   var geolocation = navigator.geolocation;
   geolocation.getCurrentPosition(showLocation, errorHandler, {maximumAge: 75000});
}

Les microdonnées sont un moyen standardisé de fournir une sémantique supplémentaire dans vos pages Web.

Microdata vous permet de définir vos propres éléments personnalisés et de commencer à intégrer des propriétés personnalisées dans vos pages Web. À un niveau élevé, les microdonnées consistent en un groupe de paires nom-valeur.

Les groupes sont appelés items, et chaque paire nom-valeur est un property. Les éléments et les propriétés sont représentés par des éléments réguliers.

Exemple

  • Pour créer un élément, le itemscope l'attribut est utilisé.

  • Pour ajouter une propriété à un élément, le itemprop L'attribut est utilisé sur l'un des descendants de l'élément.

Ici, il y a deux éléments, dont chacun a la propriété "nom" -

<html>
   <body>
      
      <div itemscope>
         <p>My name is <span itemprop = "name">Zara</span>.</p>
      </div>
      
      <div itemscope>
         <p>My name is <span itemprop = "name">Nuha</span>.</p>
      </div>
      
   </body>
</html>

Il produira le résultat suivant -

Les propriétés ont généralement des valeurs qui sont des chaînes, mais elles peuvent avoir les types de données suivants -

Attributs globaux

Microdata introduit cinq attributs globaux qui seraient disponibles pour tout élément à utiliser et donnent un contexte aux machines sur vos données.

N ° Sr. Attribut et description
1

itemscope

Ceci est utilisé pour créer un élément. L'attribut itemscope est un attribut booléen qui indique qu'il y a des microdonnées sur cette page, et c'est là que ça commence.

2

itemtype

Cet attribut est une URL valide qui définit l'élément et fournit le contexte des propriétés.

3

itemid

Cet attribut est l'identifiant global de l'article.

4

itemprop

Cet attribut définit une propriété de l'élément.

5

itemref

Cet attribut donne une liste d'éléments supplémentaires à explorer pour trouver les paires nom-valeur de l'élément.

Propriétés des types de données

Les propriétés ont généralement des valeurs qui sont des chaînes comme mentionné dans l'exemple ci-dessus, mais elles peuvent également avoir des valeurs qui sont des URL. L'exemple suivant a une propriété, "image", dont la valeur est une URL -

<div itemscope>
   <img itemprop = "image" src = "tp-logo.gif" alt = "TutorialsPoint">
</div>

Les propriétés peuvent également avoir des valeurs qui sont des dates, des heures ou des dates et des heures. Ceci est réalisé en utilisant letime élément et son datetime attribut.

<html>
   <body>
      
      <div itemscope>
         My birthday is:
         <time itemprop = "birthday" datetime = "1971-05-08">
            Aug 5th 1971
         </time>
      </div>
      
   </body>
</html>

Il produira le résultat suivant -

Les propriétés peuvent également elles-mêmes être des groupes de paires nom-valeur, en plaçant l'attribut itemscope sur l'élément qui déclare la propriété.

Prise en charge de l'API Microdata

Si un navigateur prend en charge l'API de microdonnées HTML5, il y aura une fonction getItems () sur l'objet de document global. Si le navigateur ne prend pas en charge les microdonnées, la fonction getItems () ne sera pas définie.

function supports_microdata_api() {
   return !!document.getItems;
}

Modernizr ne prend pas encore en charge la vérification de l'API de microdonnées, vous devrez donc utiliser la fonction comme celle répertoriée ci-dessus.

La norme de microdonnées HTML5 comprend à la fois un balisage HTML (principalement pour les moteurs de recherche) et un ensemble de fonctions DOM (principalement pour les navigateurs).

Vous pouvez inclure un balisage de microdonnées dans vos pages Web, et les moteurs de recherche qui ne comprennent pas les attributs des microdonnées les ignoreront tout simplement. Mais si vous avez besoin d'accéder ou de manipuler des microdonnées via le DOM, vous devrez vérifier si le navigateur prend en charge l'API DOM des microdonnées.

Définition du vocabulaire des microdonnées

Pour définir le vocabulaire des microdonnées, vous avez besoin d'une URL d'espace de noms qui pointe vers une page Web de travail. Par exemple, https://data-vocabulary.org/Person peut être utilisé comme espace de noms pour un vocabulaire de microdonnées personnelles avec les propriétés nommées suivantes -

  • name - Nom de la personne sous forme de chaîne simple

  • Photo - Une URL vers une photo de la personne.

  • URL - Un site Internet appartenant à la personne.

L'utilisation des microdonnées sur les propriétés d'une personne pourrait être la suivante -

<html>
   <body>
   
      <div itemscope>
         <section itemscope itemtype = "http://data-vocabulary.org/Person">
            <h1 itemprop = "name">Gopal K Varma</h1>
         
            <p>
               <img itemprop = "photo" 
                  src = "http://www.tutorialspoint.com/green/images/logo.png">
            </p>
            
            <a itemprop = "url" href = "#">Site</a>
         </section>
      </div>
      
   </body>
</html>

Il produira le résultat suivant -

Google prend en charge les microdonnées dans le cadre de son programme Rich Snippets. Lorsque le robot d'exploration de Google analyse votre page et trouve des propriétés de microdonnées conformes au vocabulaire http://datavocabulary.org/Person, il analyse ces propriétés et les stocke avec le reste des données de la page.

Vous pouvez tester l'exemple ci-dessus à l'aide de l' outil de test Rich Snippets en utilisant http://www.tutorialspoint.com/html5/microdata.htm

Pour un développement ultérieur sur les microdonnées, vous pouvez toujours vous référer aux microdonnées HTML5 .

Drag and Drop (DnD) est un puissant concept d'interface utilisateur qui facilite la copie, la réorganisation et la suppression d'éléments à l'aide de clics de souris. Cela permet à l'utilisateur de cliquer et de maintenir le bouton de la souris enfoncé sur un élément, de le faire glisser vers un autre emplacement et de relâcher le bouton de la souris pour y déposer l'élément.

Pour obtenir la fonctionnalité de glisser-déposer avec HTML4 traditionnel, les développeurs devraient soit utiliser une programmation JavaScript complexe, soit d'autres frameworks JavaScript tels que jQuery, etc.

Maintenant, HTML 5 est venu avec une API Drag and Drop (DnD) qui apporte le support DnD natif au navigateur, ce qui facilite beaucoup le codage.

HTML 5 DnD est pris en charge par tous les principaux navigateurs tels que Chrome, Firefox 3.5 et Safari 4, etc.

Glisser-déposer des événements

Un certain nombre d'événements sont déclenchés au cours des différentes étapes de l'opération de glisser-déposer. Ces événements sont listés ci-dessous -

N ° Sr. Événements et description
1

dragstart

Se déclenche lorsque l'utilisateur commence à faire glisser l'objet.

2

dragenter

Déclenché lorsque la souris est déplacée pour la première fois sur l'élément cible alors qu'un glissement se produit. Un écouteur pour cet événement doit indiquer si une suppression est autorisée sur cet emplacement. S'il n'y a pas d'écouteurs ou si les écouteurs n'effectuent aucune opération, une suppression n'est pas autorisée par défaut.

3

dragover

Cet événement est déclenché lorsque la souris est déplacée sur un élément lorsqu'un glissement se produit. La plupart du temps, l'opération qui se produit pendant un écouteur sera la même que l'événement dragenter.

4

dragleave

Cet événement est déclenché lorsque la souris quitte un élément pendant qu'un glissement se produit. Les auditeurs doivent supprimer tous les marqueurs de surlignage ou d'insertion utilisés pour les commentaires de suppression.

5

drag

Se déclenche à chaque fois que la souris est déplacée pendant que l'objet est déplacé.

6

drop

L'événement de dépôt est déclenché sur l'élément où le dépôt a eu lieu à la fin de l'opération de glissement. Un auditeur serait chargé de récupérer les données glissées et de les insérer à l'emplacement de dépôt.

sept

dragend

Se déclenche lorsque l'utilisateur relâche le bouton de la souris tout en faisant glisser un objet.

Note- Notez que seuls les événements de glissement sont déclenchés; les événements de souris tels que mousemove ne sont pas déclenchés pendant une opération de glissement.

L'objet DataTransfer

Les méthodes d'écoute d'événements pour tous les événements de glisser-déposer acceptent Event objet qui a un attribut en lecture seule appelé dataTransfer.

le event.dataTransfer Retour DataTransfer objet associé à l'événement comme suit -

function EnterHandler(event) {
   DataTransfer dt = event.dataTransfer;
   .............
}

L' objet DataTransfer contient des données sur l'opération de glisser-déposer. Ces données peuvent être récupérées et définies en termes de divers attributs associés à l'objet DataTransfer comme expliqué ci-dessous -

N ° Sr. Attributs DataTransfer et leur description
1

dataTransfer.dropEffect [ = value ]

  • Renvoie le type d'opération actuellement sélectionné.

  • Cet attribut peut être défini pour modifier l'opération sélectionnée.

  • Les valeurs possibles sont none, copy, link et move.

2

dataTransfer.effectAllowed [ = value ]

  • Renvoie les types d'opérations à autoriser.

  • Cet attribut peut être défini pour modifier les opérations autorisées.

  • Les valeurs possibles sont none, copy, copyLink, copyMove, link, linkMove, move, all et uninitialized.

3

dataTransfer.types

Renvoie une DOMStringList répertoriant les formats définis dans l'événement dragstart. De plus, si des fichiers sont glissés, l'un des types sera la chaîne "Fichiers".

4

dataTransfer.clearData ( [ format ] )

Supprime les données des formats spécifiés. Supprime toutes les données si l'argument est omis.

5

dataTransfer.setData(format, data)

Ajoute les données spécifiées.

6

data = dataTransfer.getData(format)

Renvoie les données spécifiées. S'il n'y a pas de telles données, renvoie la chaîne vide.

sept

dataTransfer.files

Renvoie une FileList des fichiers en cours de glissement, le cas échéant.

8

dataTransfer.setDragImage(element, x, y)

Utilise l'élément donné pour mettre à jour les commentaires de glissement, en remplaçant tous les commentaires précédemment spécifiés.

9

dataTransfer.addElement(element)

Ajoute l'élément donné à la liste des éléments utilisés pour rendre le retour de glissement.

Processus de glisser-déposer

Voici les étapes à suivre pour implémenter l'opération de glisser-déposer -

Étape 1 - Rendre un objet déplaçable

Voici les étapes à suivre -

  • Si vous souhaitez faire glisser un élément, vous devez définir le draggable attribuer à true pour cet élément.

  • Définir un écouteur d'événements pour dragstart qui stocke les données glissées.

  • L'auditeur d'événement dragstart définira les effets autorisés (copie, déplacement, lien ou une combinaison).

Voici l'exemple pour rendre un objet déplaçable -

<!DOCTYPE HTML>

<html>
   <head>
      
      <style type = "text/css">
         
         #boxA, #boxB {
            float:left;padding:10px;margin:10px; -moz-user-select:none;
         }
         #boxA { background-color: #6633FF; width:75px; height:75px;  }
         #boxB { background-color: #FF6699; width:150px; height:150px; }
      </style>
      
      <script type = "text/javascript">
         
         function dragStart(ev) {
            ev.dataTransfer.effectAllowed = 'move';
            ev.dataTransfer.setData("Text", ev.target.getAttribute('id'));
            ev.dataTransfer.setDragImage(ev.target,0,0);
            
            return true;
         }
      </script>
      
   </head>
   <body>
      
      <center>
         <h2>Drag and drop HTML5 demo</h2>
         <div>Try to drag the purple box around.</div>
         
         <div id = "boxA" draggable = "true" 
            ondragstart = "return dragStart(ev)">
            <p>Drag Me</p>
         </div>
         
         <div id = "boxB">Dustbin</div>
      </center>
      
   </body>
</html>

Cela produira le résultat suivant -

Étape 2 - Déposer l'objet

Pour accepter un dépôt, la cible de dépôt doit écouter au moins trois événements.

  • le dragenterévénement, qui est utilisé pour déterminer si la cible de dépôt doit accepter ou non la suppression. Si la dépose doit être acceptée, cet événement doit être annulé.

  • le dragoverévénement, qui est utilisé pour déterminer quel retour d'information doit être montré à l'utilisateur. Si l'événement est annulé, le retour (généralement le curseur) est mis à jour en fonction de la valeur de l'attribut dropEffect.

  • Finalement, le drop événement, qui permet d'effectuer la suppression réelle.

Voici l'exemple pour déposer un objet dans un autre objet -

<html>
   <head>
      <style type="text/css">
         #boxA, #boxB {
            float:left;padding:10px;margin:10px;-moz-user-select:none;
         }
         #boxA { background-color: #6633FF; width:75px; height:75px;  }
         #boxB { background-color: #FF6699; width:150px; height:150px; }
      </style>
      <script type="text/javascript">
         function dragStart(ev) {
            ev.dataTransfer.effectAllowed='move';
            ev.dataTransfer.setData("Text", ev.target.getAttribute('id'));
            ev.dataTransfer.setDragImage(ev.target,0,0);
            return true;
         }
         function dragEnter(ev) {
            event.preventDefault();
            return true;
         }
         function dragOver(ev) {
            return false;
         }
         function dragDrop(ev) {
            var src = ev.dataTransfer.getData("Text");
            ev.target.appendChild(document.getElementById(src));
            ev.stopPropagation();
            return false;
         }
      </script>
   </head>
   <body>
      <center>
         <h2>Drag and drop HTML5 demo</h2>
         <div>Try to move the purple box into the pink box.</div>
         <div id="boxA" draggable="true" ondragstart="return dragStart(event)">
            <p>Drag Me</p>
         </div>
         <div id="boxB" ondragenter="return dragEnter(event)" ondrop="return dragDrop(event)" ondragover="return dragOver(event)">Dustbin</div>
      </center>
   </body>
</html>

Cela produira le résultat suivant -

JavaScript a été conçu pour s'exécuter dans un environnement à thread unique, ce qui signifie que plusieurs scripts ne peuvent pas s'exécuter en même temps. Imaginez une situation dans laquelle vous devez gérer les événements de l'interface utilisateur, interroger et traiter de grandes quantités de données API et manipuler le DOM.

JavaScript bloquera votre navigateur dans une situation où l'utilisation du processeur est élevée. Prenons un exemple simple où JavaScript passe par une grande boucle -

<!DOCTYPE HTML>

<html>
   <head>
      <title>Big for loop</title>
      
      <script>
         function bigLoop() {
            
            for (var i = 0; i <= 10000; i += 1) {
               var j = i;
            }
            alert("Completed " + j + "iterations" );
         }
         
         function sayHello(){
            alert("Hello sir...." );
         }
      </script>
      
   </head>
   
   <body>
      <input type = "button" onclick = "bigLoop();" value = "Big Loop" />
      <input type = "button" onclick = "sayHello();" value = "Say Hello" />
   </body>
</html>

Il produira le résultat suivant -

Lorsque vous cliquez sur le bouton Big Loop, il affiche le résultat suivant dans Firefox -

Qu'est-ce que les Web Workers?

La situation expliquée ci-dessus peut être gérée en utilisant Web Workers qui effectuera toutes les tâches coûteuses en calcul sans interrompre l'interface utilisateur et s'exécutera généralement sur des threads séparés.

Les Web Workers autorisent des scripts de longue durée qui ne sont pas interrompus par des scripts qui répondent aux clics ou à d'autres interactions de l'utilisateur, et permettent d'exécuter des tâches longues sans céder à la réactivité de la page.

Les Web Workers sont des scripts d'arrière-plan et ils sont relativement lourds et ne sont pas destinés à être utilisés en grand nombre. Par exemple, il serait inapproprié de lancer un worker pour chaque pixel d'une image de quatre mégapixels.

Lorsqu'un script s'exécute dans un Web Worker, il ne peut pas accéder à l'objet de fenêtre de la page Web (window.document), ce qui signifie que les Web Workers n'ont pas d'accès direct à la page Web et à l'API DOM. Bien que les Web Workers ne puissent pas bloquer l'interface utilisateur du navigateur, ils peuvent toujours consommer des cycles de processeur et rendre le système moins réactif.

Comment fonctionnent les Web Workers?

Les Web Workers sont initialisés avec l'URL d'un fichier JavaScript, qui contient le code que le worker exécutera. Ce code définit les écouteurs d'événements et communique avec le script qui l'a engendré à partir de la page principale. Voici la syntaxe simple -

var worker = new Worker('bigLoop.js');

Si le fichier javascript spécifié existe, le navigateur génère un nouveau thread de travail, qui est téléchargé de manière asynchrone. Si le chemin d'accès à votre worker renvoie une erreur 404, le worker échouera silencieusement.

Si votre application comporte plusieurs fichiers JavaScript pris en charge, vous pouvez les importer importScripts() méthode qui prend le (s) nom (s) de fichier comme argument séparé par une virgule comme suit -

importScripts("helper.js", "anotherHelper.js");

Une fois le Web Worker créé, la communication entre le Web Worker et sa page parente se fait à l'aide du postMessage()méthode. En fonction de votre navigateur / version, postMessage () peut accepter une chaîne ou un objet JSON comme argument unique.

Le message transmis par Web Worker est accessible via onmessageévénement dans la page principale. Maintenant, écrivons notre exemple bigLoop en utilisant Web Worker. Ci-dessous se trouve la page principale (hello.htm) qui engendrera un travailleur Web pour exécuter la boucle et renvoyer la valeur finale de la variablej -

<!DOCTYPE HTML>

<html>
   <head>
      <title>Big for loop</title>
      
      <script>
         var worker = new Worker('bigLoop.js');
         
         worker.onmessage = function (event) {
            alert("Completed " + event.data + "iterations" );
         };
         
         function sayHello() {
            alert("Hello sir...." );
         }
      </script>
   </head>
   
   <body>
      <input type = "button" onclick = "sayHello();" value = "Say Hello"/>
   </body>
</html>

Voici le contenu du fichier bigLoop.js. Cela fait usage depostMessage() API pour renvoyer la communication à la page principale -

for (var i = 0; i <= 1000000000; i += 1) {
   var j = i;
}
postMessage(j);

Cela produira le résultat suivant -

Arrêt des travailleurs Web

Les Web Workers ne s'arrêtent pas seuls mais la page qui les a lancés peut les arrêter en appelant terminate() méthode.

worker.terminate();

Un Web Worker arrêté ne répondra plus aux messages et n'effectuera plus de calculs supplémentaires. Vous ne pouvez pas redémarrer un travailleur; à la place, vous pouvez créer un nouveau collaborateur en utilisant la même URL.

Traitement des erreurs

L'exemple suivant montre un exemple de fonction de gestion des erreurs dans un fichier JavaScript Web Worker qui enregistre les erreurs dans la console. Avec le code de gestion des erreurs, l'exemple ci-dessus deviendrait comme suit -

<!DOCTYPE HTML>

<html>
   <head>
      <title>Big for loop</title>
      
      <script>
         var worker = new Worker('bigLoop.js');
         
         worker.onmessage = function (event) {
            alert("Completed " + event.data + "iterations" );
         };
         
         worker.onerror = function (event) {
            console.log(event.message, event);
         };
         
         function sayHello() {
            alert("Hello sir...." );
         }
      </script>
   </head>
   
   <body>
      <input type = "button" onclick = "sayHello();" value = "Say Hello"/>
   </body>
</html>

Vérification de la prise en charge du navigateur

Voici la syntaxe permettant de détecter la prise en charge d'une fonctionnalité Web Worker disponible dans un navigateur:

<!DOCTYPE HTML>

<html>
   <head>
      <title>Big for loop</title>
      <script src = "/js/modernizr-1.5.min.js"></script>
      
      <script>
      function myFunction() {
         
         if (Modernizr.webworkers) {
            alert("Congratulation!! you have web workers support." );
         } else {
            alert("Sorry!! you do not have web workers support." );
         }
      }
      </script>
   </head>
   
   <body>
      <button onclick = "myFunction()">Click me</button>
   </body>
</html>

Cela produira le résultat suivant -

L'indexeddb est un nouveau concept HTML5 pour stocker les données dans le navigateur de l'utilisateur. indexeddb est plus puissant que le stockage local et utile pour les applications qui nécessitent de stocker une grande quantité de données. Ces applications peuvent fonctionner plus efficacement et se charger plus rapidement.

Pourquoi utiliser indexeddb?

Le W3C a annoncé que la base de données Web SQL est une spécification de stockage local obsolète, de sorte que les développeurs Web ne devraient plus utiliser cette technologie. indexeddb est une alternative à la base de données Web SQL et plus efficace que les anciennes technologies.

traits

  • il stocke les valeurs des paires de clés
  • ce n'est pas une base de données relationnelle
  • L'API IndexedDB est principalement asynchrone
  • ce n'est pas un langage de requête structuré
  • il a pris en charge l'accès aux données du même domaine

IndexedDB

Avant d'entrer dans un indexeddb, nous devons ajouter quelques préfixes d'implémentation comme indiqué ci-dessous

window.indexedDB = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || 
window.msIndexedDB;
 
window.IDBTransaction = window.IDBTransaction || window.webkitIDBTransaction || 
window.msIDBTransaction;
window.IDBKeyRange = window.IDBKeyRange || 
window.webkitIDBKeyRange || window.msIDBKeyRange
 
if (!window.indexedDB) {
   window.alert("Your browser doesn't support a stable version of IndexedDB.")
}

Ouvrez une base de données IndexedDB

Avant de créer une base de données, nous devons préparer certaines données pour le début de la base de données .let avec les détails des employés de l'entreprise.

const employeeData = [
   { id: "01", name: "Gopal K Varma", age: 35, email: "[email protected]" },
   { id: "02", name: "Prasad", age: 24, email: "[email protected]" }
];

Ajout des données

Ici, ajouter manuellement des données dans les données comme indiqué ci-dessous -

function add() {
   var request = db.transaction(["employee"], "readwrite")
   .objectStore("employee")
   .add({ id: "01", name: "prasad", age: 24, email: "[email protected]" });
   
   request.onsuccess = function(event) {
      alert("Prasad has been added to your database.");
   };
   
   request.onerror = function(event) {
      alert("Unable to add data\r\nPrasad is already exist in your database! ");
   }
}

Récupération des données

Nous pouvons récupérer les données de la base de données en utilisant avec get ()

function read() {
   var transaction = db.transaction(["employee"]);
   var objectStore = transaction.objectStore("employee");
   var request = objectStore.get("00-03");
   
   request.onerror = function(event) {
      alert("Unable to retrieve daa from database!");
   };
   
   request.onsuccess = function(event) {
      
      if(request.result) {
         alert("Name: " + request.result.name + ", Age: 
            " + request.result.age + ", Email: " + request.result.email);
      } else {
         alert("Kenny couldn't be found in your database!");  
      }
   };
}

En utilisant get (), nous pouvons stocker les données dans un objet au lieu de cela, nous pouvons stocker les données dans le curseur et nous pouvons récupérer les données du curseur.

function readAll() {
   var objectStore = db.transaction("employee").objectStore("employee");
   
   objectStore.openCursor().onsuccess = function(event) {
      var cursor = event.target.result;
      
      if (cursor) {
         alert("Name for id " + cursor.key + " is " + cursor.value.name + ", 
            Age: " + cursor.value.age + ", Email: " + cursor.value.email);
         cursor.continue();
      } else {
         alert("No more entries!");
      }
   };
}

Suppression des données

Nous pouvons supprimer les données d'IndexedDB avec remove (). Voici à quoi ressemble le code

function remove() {
   var request = db.transaction(["employee"], "readwrite")
   .objectStore("employee")
   .delete("02");
   
   request.onsuccess = function(event) {
      alert("prasad entry has been removed from your database.");
   };
}

Code HTML

Pour afficher toutes les données dont nous avons besoin pour utiliser l'événement onClick comme indiqué ci-dessous le code -

<!DOCTYPE html>

<html>
   <head>
      <meta http-equiv = "Content-Type" content = "text/html; charset = utf-8" />
      <title>IndexedDb Demo | onlyWebPro.com</title>
   </head>
   
   <body>
      <button onclick = "read()">Read </button>
      <button onclick = "readAll()"></button>
      <button onclick = "add()"></button>
      <button onclick = "remove()">Delete </button>
   </body>
</html>

Le code final doit être comme -

<!DOCTYPE html>

<html>
   <head>
      <meta http-equiv = "Content-Type" content = "text/html; charset = utf-8" />
      <script type = "text/javascript">
         
         //prefixes of implementation that we want to test
         window.indexedDB = window.indexedDB || window.mozIndexedDB || 
         window.webkitIndexedDB || window.msIndexedDB;
         
         //prefixes of window.IDB objects
         window.IDBTransaction = window.IDBTransaction || 
         window.webkitIDBTransaction || window.msIDBTransaction;
         window.IDBKeyRange = window.IDBKeyRange || window.webkitIDBKeyRange || 
         window.msIDBKeyRange
         
         if (!window.indexedDB) {
            window.alert("Your browser doesn't support a stable version of IndexedDB.")
         }
         
         const employeeData = [
            { id: "00-01", name: "gopal", age: 35, email: "[email protected]" },
            { id: "00-02", name: "prasad", age: 32, email: "[email protected]" }
         ];
         var db;
         var request = window.indexedDB.open("newDatabase", 1);
         
         request.onerror = function(event) {
            console.log("error: ");
         };
         
         request.onsuccess = function(event) {
            db = request.result;
            console.log("success: "+ db);
         };
         
         request.onupgradeneeded = function(event) {
            var db = event.target.result;
            var objectStore = db.createObjectStore("employee", {keyPath: "id"});
            
            for (var i in employeeData) {
               objectStore.add(employeeData[i]);
            }
         }
         
         function read() {
            var transaction = db.transaction(["employee"]);
            var objectStore = transaction.objectStore("employee");
            var request = objectStore.get("00-03");
            
            request.onerror = function(event) {
               alert("Unable to retrieve daa from database!");
            };
            
            request.onsuccess = function(event) {
               // Do something with the request.result!
               if(request.result) {
                  alert("Name: " + request.result.name + ", 
                     Age: " + request.result.age + ", Email: " + request.result.email);
               } else {
                  alert("Kenny couldn't be found in your database!");
               }
            };
         }
         
         function readAll() {
            var objectStore = db.transaction("employee").objectStore("employee");
            
            objectStore.openCursor().onsuccess = function(event) {
               var cursor = event.target.result;
               
               if (cursor) {
                  alert("Name for id " + cursor.key + " is " + cursor.value.name + ", 
                     Age: " + cursor.value.age + ", Email: " + cursor.value.email);
                  cursor.continue();
               } else {
                  alert("No more entries!");
               }
            };
         }
         
         function add() {
            var request = db.transaction(["employee"], "readwrite")
            .objectStore("employee")
            .add({ id: "00-03", name: "Kenny", age: 19, email: "[email protected]" });
            
            request.onsuccess = function(event) {
               alert("Kenny has been added to your database.");
            };
            
            request.onerror = function(event) {
               alert("Unable to add data\r\nKenny is aready exist in your database! ");
            }
         }
         
         function remove() {
            var request = db.transaction(["employee"], "readwrite")
            .objectStore("employee")
            .delete("00-03");
            
            request.onsuccess = function(event) {
               alert("Kenny's entry has been removed from your database.");
            };
         }
      </script>
      
   </head>
   <body>
      <button onclick = "read()">Read </button>
      <button onclick = "readAll()">Read all </button>
      <button onclick = "add()">Add data </button>
      <button onclick = "remove()">Delete data </button>
   </body>
</html>

Il produira la sortie suivante -

La messagerie Web est la capacité d'envoyer des messages en temps réel du serveur au navigateur client. Il remplace le problème de communication interdomaine dans différents domaines, protocoles ou ports

Par exemple, vous souhaitez envoyer les données de votre page vers un conteneur publicitaire placé dans iframe ou voice-versa, dans ce scénario, le navigateur lève une exception de sécurité. Avec la messagerie Web, nous pouvons transmettre les données sous forme d'événement de message.

Événement de message

Les événements de message déclenchent la messagerie entre documents, la messagerie de canal, les événements envoyés par le serveur et Web sockets.it a décrit par l'interface d'événement de message.

Les attributs

N ° Sr. Attributs et description
1

data

Contient des données de chaîne

2

origin

Contient le nom de domaine et le port

3

lastEventId

Contient un identifiant unique pour l'événement de message actuel.

4

source

Contient à Une référence à la fenêtre du document d'origine

5

ports

Contient les données envoyées par n'importe quel port de message

Envoi d'un message croisé

Avant d'envoyer un message croisé de documents, nous devons créer un nouveau contexte de navigation Web en créant un nouvel iframe ou une nouvelle fenêtre. Nous pouvons envoyer les données en utilisant avec postMessage () et il a deux arguments. Ils sont comme -

  • message - Le message à envoyer
  • targetOrigin - Nom d'origine

Exemples

Envoi d'un message d'iframe au bouton

var iframe = document.querySelector('iframe');
var button = document.querySelector('button');

var clickHandler = function() {
   iframe.contentWindow.postMessage('The message to send.',
      'https://www.tutorialspoint.com);
}
button.addEventListener('click',clickHandler,false);

Réception d'un message croisé dans le document de réception

var messageEventHandler = function(event){
   
   // check that the origin is one we want.
   if(event.origin == 'https://www.tutorialspoint.com') {
      alert(event.data);
   }
}
window.addEventListener('message', messageEventHandler,false);

Messagerie de chaîne

La communication bidirectionnelle entre les contextes de navigation est appelée messagerie de canal. Il est utile pour la communication entre plusieurs origines.

Les objets MessageChannel et MessagePort

Lors de la création de messageChannel, il crée en interne deux ports pour envoyer les données et les transférer vers un autre contexte de navigation.

  • postMessage() - Publier le canal de lancement de message

  • start() - Il envoie les données

  • close() - Il ferme les ports

Dans ce scénario, nous envoyons les données d'une iframe à une autre iframe. Ici, nous invoquons les données en fonction et passons les données au DOM.

var loadHandler = function() {
   var mc, portMessageHandler;
   mc = new MessageChannel();
   window.parent.postMessage('documentAHasLoaded','http://foo.example',[mc.port2]);
   
   portMessageHandler = function(portMsgEvent) {
      alert( portMsgEvent.data );
   }
   
   mc.port1.addEventListener('message', portMessageHandler, false);
   mc.port1.start();
}
window.addEventListener('DOMContentLoaded', loadHandler, false);

Au-dessus du code, il prend les données du port 2, maintenant il passera les données à la deuxième iframe

var loadHandler = function() {
   var iframes, messageHandler;
   iframes = window.frames;
   
   messageHandler = function(messageEvent) {
      
      if( messageEvent.ports.length > 0 ) {
         
         // transfer the port to iframe[1]
         iframes[1].postMessage('portopen','http://foo.example',messageEvent.ports);
      }
   }
   window.addEventListener('message',messageHandler,false);
}
window.addEventListener('DOMContentLoaded',loadHandler,false);

Maintenant, le deuxième document gère les données à l'aide de la fonction portMsgHandler.

var loadHandler() {
   
   // Define our message handler function
   var messageHandler = function(messageEvent) {
   
      // Our form submission handler
      
      var formHandler = function() {
         var msg = 'add <[email protected]> to game circle.';
         messageEvent.ports[0].postMessage(msg);
      }
      document.forms[0].addEventListener('submit',formHandler,false);
   }
   window.addEventListener('message',messageHandler,false);
}
window.addEventListener('DOMContentLoaded',loadHandler,false);

Cross-origin resource sharing (CORS) est un mécanisme pour autoriser les ressources restreintes d'un autre domaine dans le navigateur Web.

Par exemple, si vous cliquez sur le lecteur vidéo HTML5 dans les sections de démonstration html5. il demandera la permission de la caméra. si l'utilisateur autorise la permission, alors seulement il ouvrira la caméra ou bien il n'ouvrira pas la caméra pour les applications Web.

Faire une demande CORS

Ici, Chrome, Firefox, Opera et Safari utilisent tous l'objet XMLHttprequest2 et Internet Explorer utilise l'objet similaire XDomainRequest, objet.

function createCORSRequest(method, url) {
   var xhr = new XMLHttpRequest();
   
   if ("withCredentials" in xhr) {
      
      // Check if the XMLHttpRequest object has a "withCredentials" property.
      // "withCredentials" only exists on XMLHTTPRequest2 objects.
      xhr.open(method, url, true);
   } else if (typeof XDomainRequest != "undefined") {
      
      // Otherwise, check if XDomainRequest.
      // XDomainRequest only exists in IE, and is IE's way of making CORS requests.
      xhr = new XDomainRequest();
      xhr.open(method, url);
   } else {
      
      // Otherwise, CORS is not supported by the browser.
      xhr = null;
   }
   return xhr;
}

var xhr = createCORSRequest('GET', url);

if (!xhr) {
   throw new Error('CORS not supported');
}

Poignées d'événements dans CORS

N ° Sr. Gestionnaire d'événements et description
1

onloadstart

Démarre la demande

2

onprogress

Charge les données et envoie les données

3

onabort

Annuler la demande

4

onerror

la demande a échoué

5

onload

demande de chargement avec succès

6

ontimeout

expiration du délai avant la fin de la demande

sept

onloadend

Lorsque la demande est terminée avec succès ou échec

Exemple d'événement onload ou onerror

xhr.onload = function() {
   var responseText = xhr.responseText;
   
   // process the response.
   console.log(responseText);
};

xhr.onerror = function() {
   console.log('There was an error!');
};

Exemple de CORS avec gestionnaire

L'exemple ci-dessous montrera l'exemple de makeCorsRequest () et du gestionnaire onload

// Create the XHR object.
function createCORSRequest(method, url) {
   var xhr = new XMLHttpRequest();
   
   if ("withCredentials" in xhr) {
      
      // XHR for Chrome/Firefox/Opera/Safari.
      xhr.open(method, url, true);
   } else if (typeof XDomainRequest != "undefined") {
      
      // XDomainRequest for IE.
      xhr = new XDomainRequest();
      xhr.open(method, url);
   } else {
      
      // CORS not supported.
      xhr = null;
   }
   return xhr;
}

// Helper method to parse the title tag from the response.
function getTitle(text) {
   return text.match('<title>(.*)?</title>')[1];
}

// Make the actual CORS request.
function makeCorsRequest() {
   
   // All HTML5 Rocks properties support CORS.
   var url = 'http://www.tutorialspoint.com';
   
   var xhr = createCORSRequest('GET', url);
   
   if (!xhr) {
      alert('CORS not supported');
      return;
   }
   
   // Response handlers.
   xhr.onload = function() {
      var text = xhr.responseText;
      var title = getTitle(text);
      alert('Response from CORS request to ' + url + ': ' + title);
   };
   
   xhr.onerror = function() {
      alert('Woops, there was an error making the request.');
   };
   xhr.send();
}

Web RTC introduit par le World Wide Web Consortium (W3C). Cela prend en charge les applications de navigateur à navigateur pour les appels vocaux, le chat vidéo et le partage de fichiers P2P.

Si vous voulez essayer? Web RTC disponible pour Chrome, Opera et Firefox. Un bon point de départ est l'application simple de chat vidéo ici . Web RTC implémente trois API comme indiqué ci-dessous -

  • MediaStream - accéder à la caméra et au microphone de l'utilisateur.

  • RTCPeerConnection - accéder à la fonction d'appel audio ou vidéo.

  • RTCDataChannel - accéder à la communication peer-to-peer.

MediaStream

Le MediaStream représente des flux synchronisés de médias, par exemple, cliquez sur le lecteur vidéo HTML5 dans la section de démonstration HTML5 ou cliquez ici .

L'exemple ci-dessus contient stream.getAudioTracks () et stream.VideoTracks (). S'il n'y a pas de pistes audio, il renvoie un tableau vide et il vérifie le flux vidéo, si la webcam est connectée, stream.getVideoTracks () renvoie un tableau d'un MediaStreamTrack représentant le flux de la webcam. Un exemple simple est les applications de chat, une application de chat reçoit le flux de la caméra Web, de la caméra arrière, du microphone.

Exemple de code de MediaStream

function gotStream(stream) {
   window.AudioContext = window.AudioContext || window.webkitAudioContext;
   var audioContext = new AudioContext();
   
   // Create an AudioNode from the stream
   var mediaStreamSource = audioContext.createMediaStreamSource(stream);
   
   // Connect it to destination to hear yourself
   // or any other node for processing!
   mediaStreamSource.connect(audioContext.destination);
}
navigator.getUserMedia({audio:true}, gotStream);

Capture d'écran

C'est également possible dans le navigateur Chrome avec mediaStreamSource et cela nécessite HTTPS. Cette fonctionnalité n'est pas encore disponible dans l'opéra. Un exemple de démonstration est disponible ici

Contrôle de session, informations réseau et média

Web RTC nécessitait une communication d'égal à égal entre les navigateurs. Ce mécanisme nécessitait des informations de signalisation, de réseau, de contrôle de session et de média. Les développeurs Web peuvent choisir différents mécanismes pour communiquer entre les navigateurs tels que SIP ou XMPP ou toute communication bidirectionnelle. Un exemple d'exemple de XHR est ici .

Exemple de code de createSignalingChannel ()

var signalingChannel = createSignalingChannel();
var pc;
var configuration = ...;

// run start(true) to initiate a call
function start(isCaller) {
   pc = new RTCPeerConnection(configuration);
   
   // send any ice candidates to the other peer
   pc.onicecandidate = function (evt) {
      signalingChannel.send(JSON.stringify({ "candidate": evt.candidate }));
   };
   
   // once remote stream arrives, show it in the remote video element
   pc.onaddstream = function (evt) {
      remoteView.src = URL.createObjectURL(evt.stream);
   };
   
   // get the local stream, show it in the local video element and send it
   navigator.getUserMedia({ "audio": true, "video": true }, function (stream) {
      selfView.src = URL.createObjectURL(stream);
      pc.addStream(stream);
      
      if (isCaller)
         pc.createOffer(gotDescription);
      
      else
         pc.createAnswer(pc.remoteDescription, gotDescription);
         
         function gotDescription(desc) {
            pc.setLocalDescription(desc);
            signalingChannel.send(JSON.stringify({ "sdp": desc }));
         }
      });
   }
   
   signalingChannel.onmessage = function (evt) {
      if (!pc)
         start(false);
         var signal = JSON.parse(evt.data);
      
      if (signal.sdp)
         pc.setRemoteDescription(new RTCSessionDescription(signal.sdp));
      
      else
         pc.addIceCandidate(new RTCIceCandidate(signal.candidate));
};