HTML5 - Moderniser

Modernizr est un petit JavaScript Library qui détecte la disponibilité des implémentations natives pour les technologies Web de nouvelle génération

Plusieurs nouvelles fonctionnalités sont introduites via HTML5 et CSS3, mais en même temps, de nombreux navigateurs ne prennent pas en charge ces nouvelles fonctionnalités.

Modernizr fournit un moyen facile de détecter toute nouvelle fonctionnalité afin que vous puissiez prendre les mesures correspondantes. Par exemple, si un navigateur ne prend pas en charge la fonction vidéo, vous souhaitez afficher une page simple.

Vous pouvez créer des règles CSS en fonction de la disponibilité des fonctionnalités et ces règles s'appliqueraient automatiquement sur la page Web si le navigateur ne prend pas en charge une nouvelle fonctionnalité.

Vous pouvez télécharger la dernière version de cet utilitaire à partir de Modernizr Download .

Syntaxe

Avant de commencer à utiliser Modernizr, vous devez inclure sa bibliothèque javascript dans l'en-tête de votre page HTML comme suit -

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

Comme mentionné ci-dessus, vous pouvez créer des règles CSS en fonction de la disponibilité des fonctionnalités et ces règles s'appliqueraient automatiquement sur la page Web si le navigateur ne prend pas en charge une nouvelle fonctionnalité.

Voici la syntaxe simple pour gérer les fonctionnalités prises en charge et non prises en charge -

/* In your CSS: */
.no-audio #music {
   display: none; /* Don't show Audio options */
}
.audio #music button {
   /* Style the Play and Pause buttons nicely */
}

<!-- In your HTML: -->
<div id="music">
   
   <audio>
      <source src="audio.ogg" />
      <source src="audio.mp3" />
   </audio>
   
   <button id="play">Play</button>
   <button id="pause">Pause</button>
</div>

Ici, il est à noter que vous devez préfixer "non-" à chaque fonctionnalité / propriété que vous souhaitez gérer pour le navigateur qui ne les prend pas en charge.

Voici la syntaxe pour détecter une fonctionnalité particulière via Javascript -

if (Modernizr.audio) {
   /* properties for browsers that
   support audio */
}

else{
   /* properties for browsers that
   does not support audio */
}

Fonctionnalités détectées par Modernizr

Voici la liste des fonctionnalités qui peuvent être détectées par Modernizr -

Fonctionnalité Propriété CSS Vérification JavaScript
@ font-face .fontface Modernizr.fontface
Toile .Toile Modernizr.canvas
Texte du canevas .canvastext Modernizr.canvastext
Audio HTML5 .l'audio Modernizr.audio
Formats audio HTML5 N / A Modernizr.audio [format]
Vidéo HTML5 .vidéo Modernizr.video
Formats vidéo HTML5 N / A Modernizr.video [format]
rgba () .rgba Modernizr.rgba
hsla () .hsla Modernizr.hsla
image de bordure .borderimage Modernizr.borderimage
rayon de bordure .borderradius Modernizr.borderradius
boîte ombre .boîte ombre Modernizr.boxshadow
Arrière-plans multiples .multiplebgs Modernizr.multiplebgs
opacité .opacité Opacité modernisée
Animations CSS .cssanimations Modernizr.cssanimations
Colonnes CSS .csscolumns Modernizr.csscolumns
Dégradés CSS .cssgradients Modernizr.cssgradients
Réflexions CSS .cssreflections Modernizr.cssreflections
Transformations CSS 2D .csstransforms Modernizr.csstransforms
Transformations CSS 3D .csstransforms3d Modernizr.csstransforms3d
Transitions CSS .csstransitions Modernizr.csstransitions
API de géolocalisation .geolocalisation Géolocalisation modernisée
Types d'entrée N / A Modernizr.inputtypes [type]
Attributs d'entrée N / A Modernizr.input [attribut]
stockage local .stockage local Stockage local modernisé
sessionStorage .sessionstorage Stockage de session modernisé
Travailleurs Web .webworkers Webworkers modernisés
applicationCache .applicationcache Modernizr.applicationcache
SVG .svg Modernizr.svg
Chemins de clip SVG .svgclippaths Modernizr.svgclippaths
SMIL .smil Modernizr.smil
Base de données Web SQL .websqldatabase Modernizr.websqldatabase
IndexedDB .indexeddb Modernizr.indexeddb
Prises Web .websockets Modernizr.websockets
Événement Hashchange .hashchange Modernizr.hashchange
Gestion de l'histoire .historymanagement Gestion de l'histoire modernisée
Glisser déposer .glisser déposer Modernizr.draganddrop
Messagerie inter-fenêtres .crosswindowmessaging Messagerie de fenêtre croisée modernisée
AddTest () Plugin API N / A Modernizr.addTest (str, fn)