Loading AI tools
type de développement de logiciel De Wikipédia, l'encyclopédie libre
La programmation web est la programmation informatique qui permet d'éditer des sites web. Elle permet la création d'applications destinées à être déployées sur Internet ou en Intranet. Ces applications web sont constituées de pages web pouvant prendre différentes formes telles que :
Pour un internaute qui fait appel à une URL, la page web correspondante, qu'elle soit statique ou dynamique, consiste en du code « côté client » (HTML, CSS, Javascript, ...) qui est interprété par son navigateur (Google Chrome, Firefox, ...) produisant une interface utilisateur. Ce code, qui est renvoyé par un serveur web, peut ou non avoir été généré par du calcul « côté serveur », via des langages de programmation particuliers, pouvant faire appel à des bases de données, des API...
Il existe différentes techniques et différents langages permettant de construire des sites web par l'intermédiaire de serveurs web, que l'on peut classer selon deux principes : des langages de programmation côté client, ou côté serveur. Cette distinction est faite pour séparer les langages « côté serveur » dont le code est exécuté sur le serveur web avant d'arriver sur le navigateur de l'utilisateur, des langages « côté client » dont l'exécution ne nécessite pas de calcul sur le serveur web mais, seulement après le téléchargement de la page, une interprétation par le navigateur de l'utilisateur.
Lorsqu'un visiteur demande une page en tapant une adresse ou URL, le serveur web lui renvoie le contenu de la page demandée, le plus souvent en HTML, Javascript ou XML.
C'est ensuite le navigateur web qui interprète le contenu retourné, en utilisant ou non des plug-ins qui interprètent certains objets.
La programmation "côté client" (ou développement web frontal) consiste à produire du code (HTML, CSS, Javascript, ...) qui sera interprété par un navigateur web (ou une fenêtre, pour les logiciels de bureau ou applications mobiles) et produira un rendu visuel : une interface utilisateur (UI), et dont certains éléments permettront une navigation, des liens, avec les autres pages (UX).
Toute page web comprend une base de langage HTML ou XHTML. Il s'agit d'un langage de balisage qui définit essentiellement la structure de la page web (titres, tableaux, paragraphes, listes, etc.).
Initialement, c'est un langage qui permet de créer des hyperliens, à savoir des liens d'un document à un autre ou d'un endroit d'un document à un autre endroit du même document (identificateur de fragment).
Ce langage ne définissait au départ que la structure de la page, mais très vite se sont rajoutées des balises (ou tags) qui s'occupaient de spécifier les caractéristiques de la page web (hiérarchisation du contenu, attributs donnés aux balises...).
Depuis sa version 4, le langage HTML s'accompagne des CSS qui sont des styles se chargeant de la mise en forme et de l'animation de la page.
Le XHTML est une évolution du HTML basée sur XML.
Pour rendre une page web plus dynamique en HTML, il est possible d'y insérer des objets, grâce aux tags <object>, <img>, <applet> ou <script> par exemple.
Un premier type d'objet sont les images qu'on intègre dans la page web. Les images sont généralement statiques sauf les gifs animés.
L'intégration de documents multimédia (son ou vidéo).
Animation Flash (obsolète)
Flash (de Adobe Systems - Macromedia) était un programme qui permettait de créer des animations dans un format vectoriel propriétaire relativement léger. Le programme génèrait un fichier avec l'extension .fla qui est le fichier de travail et qui sera 'compilé' en un fichier avec l'extension .swf. Swift était un autre programme générant des fichiers swf hors de la sphère Macromedia.
Dans une page web, une animation Flash (fichier avec extension .swf) pouvait être intégrée comme partie de la page (une publicité, un menu, ...) ou l'ensemble de la page pouvait être en flash mais il y avait toujours un squelette HTML.
Flash permettait de créer des animations de qualité, permettait une certaine interaction avec l'utilisateur grâce au langage de programmation ActionScript (dérivé de ECMAScript comme JavaScript). Les dernières versions de Flash permettaient également l'interfaçage avec une base de données.
Adobe Flash Player est officiellement abandonné en [1], ainsi que son support dans les navigateurs web.
Applet Java (appliquette) (obsolète)
Il était également possible de créer des petits programmes avec interface dans un langage de programmation comme Java. Ces petits programme étaient appelés Applets ou appliquettes. Ils étaient complètement autonomes mais éventuellement paramétrables et s'intègraient dans une page web. Ils étaient téléchargés avec la page web et exécutés par l'ordinateur client.
Le code était indépendant de la plate forme grâce à la machine virtuelle Java.
ActiveX (obsolète)
Les ActiveX étaient une solution de création d'applications développée par Microsoft. Les principes de fonctionnement étaient très semblables au fonctionnement des applets. Voir aussi Component Object Model
Une page web créée en HTML est totalement statique et n'offre qu'une faible possibilité d'interaction avec le visiteur. Chaque page doit être créée au préalable et doit être manuellement mise à jour.
Le langage HTML est multiplateformes. Tous les navigateurs web reconnaissent le langage HTML de base, seuls certaines balises ou attributs sont propres à certains navigateurs. Les CSS, même s'ils sont standardisés par le W3C, ne sont pas toujours reconnus de la même manière par les différents navigateurs web.
Les composants web permettent aux développeurs de créer des balises HTML personnalisées et réutilisables.
Le langage HTML a l'avantage d'être facile à mettre en place, et ne demande pas de compétences techniques très poussées. Ses pages sont d'un traitement très léger et rapide par le serveur.
Le langage de balisage XML peut également servir de base à une page web. Le fichier XML contiendra le contenu de la page web.
Ce fichier peut être lié à un fichier XSL (Feuilles de style XML) qui mettra en forme les données du fichier XML.
La plupart du temps, la page web ne sera pas basée sur un fichier XML natif mais celui-ci sera généré dynamiquement par un des langages de programmation web ci-dessous.
Le CSS (cascading style sheets, feuilles de style en cascade) est un langage de programmation permettant la mise en forme d'une page web. L'HTML et le CSS sont complémentaires.
La programmation côté client utilise des langages de scripts. À la différence des langages de programmation côté serveur, ces langages ne sont pas compilés. Ils sont interprétés par le navigateur web du visiteur.
Les langages de script sont utilisés au départ dans le cas de validation de formulaires (champs obligatoires, petits calculs, ...) et dans la création d'animations sur le navigateur de l'utilisateur (menus déroulants, rafraîchissement du contenu sans rechargement de la page, …). Ils permettent toutefois, aujourd'hui, de faire beaucoup plus, tels que la création de jeux vidéo (API Canvas), la création d’environnements sonores (API Web Audio), la communication en temps réel (API RTC), etc.
Dès le milieu des années 2010, la programmation Script est devenue très courante pour le développement d'applications web complètes avec l'arrivée de plateformes logicielles et de frameworks open-source basés sur JavaScript, très documentés et largement recommandées par la communauté des développeurs, tels que le programme Node.js, mais également les frameworks et librairies Vue.js (indépendant), ReactJS (Facebook) ou encore AngularJS (Google).
Il existe historiquement plusieurs langages de script :
Lorsqu'un visiteur demande (ou requête) le chargement d'une URL sur son navigateur, un appel (le plus souvent via HTTP ou HTTPS) est effectué sur le serveur web qui héberge le site correspondant. Le serveur web va ensuite identifier le ou les scripts (écrits dans un langage « côté serveur ») correspondant à cette URL, et demander leur exécution. L'exécution va alors résulter en un contenu HTML, qui va ensuite être expédié en réponse au visiteur, lisible par son navigateur.
La programmation "côté serveur" consiste donc à produire du code dont l'exécution, du calcul et de la récupération de données externes (bases de données, API, ...), va résulter en un contenu qui sera envoyé au client. Ce contenu peut être du code "côté client".
Il est possible de mettre en place un serveur web en utilisant le programme Node.js, exposant des URL, via notamment Express.js, à un projet de code développé en Javascript.
PHP (PHP: Hypertext Preprocessor) est un langage de script interprété côté serveur. Le code PHP est lu par le serveur et interprété pour produire une page HTML (ou d'autres types de fichier comme des images ou des documents PDF) à chaque fois que la page sera demandée. Ce langage a été créé initialement dans le cadre des logiciels Open Source. De nombreux développeurs ont ensuite profité de l'Open Source pour développer de nombreux modules prêts à l'usage et paramétrables à volonté.
Les modules serveurs de PHP sont implémentés sur les serveurs Apache et Unix mais PHP peut être implémenté sur d'autres plates-formes via des CGI.
La syntaxe, relativement simple, part d'une base de C.
Django : Framework open-source largement répandu pour construire et déployer une application côté serveur en Python.
Ruby on Rails : Framework open-source largement répandu pour construire et déployer une application côté serveur en Ruby.
Il est possible de développer un site web « côté serveur » en C++, notamment avec des framework tels que Wt, ou CppCMS par exemple.
ColdFusion est une technique de création de pages dynamiques développée par Macromedia. Les pages d’application sont des pages web contenant des instructions de programmation écrite à l’aide d’un langage propriétaire, le CFML (ColdFusion Markup Language). Le CFML est un langage simple basé sur des balises dont la syntaxe est similaire à celles du langage HTML mais interprétées par le serveur.
Chacun de ces langages, pour permettre de construire des pages dont le contenu et les données sont construits dynamiquement en fonction de l'usage des utilisateurs ou d'autres paramètres externes, peut faire appel à une ou plusieurs bases de données.
Il en existe de nombreuses sortes : dBase, filePro, Firebird/InterBase, FrontBase, IBM DB2, Cloudscape, Informix, Ingres, EDBC, Enterprise Access, Mssql, MySQL, PostgreSQL, SQLite, SQLite3, SQLSRV, Sybase, MariaDB.
AJAX (Asynchronous JavaScript And XML) est une technique, avec ses avantages et inconvénients[2], qui combine plusieurs éléments :
Cette technique permet d'effectuer une requête HTTP asynchrone (en parallèle) depuis un client au serveur web (effectuer une action, mettre à jour une information...). Le serveur renvoie la ressource demandée, pouvant contenir des informations ou du code permettant de jour la page HTML.
Depuis le milieu des années 2010, avec l'arrivée de standards plus modernes du web, AJAX (dont la définition est associée à l'API XMLHttpRequest) est progressivement remplacé par de nouvelles fonctions telle que fetch() (API Fetch) qui repose sur un principe de « promesse » et d'appel d'une ressource réseau en tâche de fond[3],[4]. Ou encore les communications serveur vers client comme le protocole Mercure[5]. Le principe reste le même : faire communiquer, sans rechargement, une interface client avec une ressource sur un serveur.
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.