====== Devweb 102 : Le responsive & Bootstrap ====== Cette seconde formation permet d'avoir une vue plus actuelle du développement web en présentant les outils du développeur d'aujourd'hui. ** Compétences abordées : ** HTML, CSS, Responsive, Media Queries, Inspecteur d’éléments, Bootstrap ===== Prérequis ===== Avoir suivi la formation [[formations:devweb_1]]. Pour accéder aux fichiers depuis son ordi personnel on utilise FileZilla. Son utilisation est décrite ici : [[tutoriels:ssh#transfert_de_fichiers|Transfert de fichiers]]. ===== L'Inspecteur d'Éléments ===== L’inspecteur d’éléments fait partie des outils indispensables aux développeurs pour leurs tests de rendu. En fonction des navigateurs, il a des noms différents : * **Firefox :** examiner l’élément * **Google Chrome :** inspecter * **Safari :** inspecter l’élément On y accède via clic droit sur le corps de la page qui nous intéresse. On illustrera l’utilisation de cet outil sur Google Chrome. ==== Interface ==== {{ :formations:inspecteur.png?400 |}} On voit ici l'interface de l'inspecteur sur Google Chrome. Les sections encadrées en rouge sont celles dont nous nous servons en général. ===Le panneau HTML et le panneau CSS=== {{ :formations:htlmcss-01.png?400 |}} Grâce au panneau HTML, il est possible d'examiner et d'éditer le code HTML d'une page en direct. Voici un exemple très simple avec MyCentraleAssos : {{ :formations:htmledit1.png?800 |}} {{ :formations:htmledit2.png?800 |}} On voit ici que le titre, une fois changé dans le code, est modifié sur la vue. Survoler une ligne dans le panneau HTML le mettra en surbrillance dans la page. Lorsqu'une ligne du code HTML est sélectionnée, le panneau CSS affiche tous les styles qui s'appliquent à l'élément sélectionné. Il est ainsi possible, ici encore, de modifier les propriétés qui s'appliquent pour chaque élément. {{ :formations:editcss1-01.png?800 |}} Ici on a modifié la taille du texte. Cependant, il arrive que certaines propriétés notées dans "Style" soient pas actives (par exemple la couleur est barrée ci-dessous). Cela est dû à d'autres propriétés surplombant la première. Attention, éditer le code dans l'inspecteur ne modifiera en aucun cas le code réel de votre page. L'inspecteur n'est là que pour vous permettre d'expérimenter. Si vous voulez rendre vos modifications permanentes, il faut modifier le code source de votre page. ===Le sélecteur d'éléments=== Le sélecteur d'éléments permet de remonter à la position d'un élément dans le code HTML en le sélectionnant sur le corps de la page elle même.{{ :formations:pointer.png|}} ===Le Toggle device mode=== Le Toggle device mode permet d'afficher la page actuelle sur la vue correspondant à une résolution d'écran différente au choix.{{ :formations:toogledevicemode.png|}} ===Console=== La console affiche des informations associées à la page web active. Cela comprend les requêtes réseau, le JavaScript, le CSS, les erreurs et avertissements de sécurité. Elle permet également d'interagir avec la page web en exécutant du JavaScript. ===Réseau=== ===== Responsive, qu'est ce que c'est ? ===== Lorsque l’on construit un site web, il faut veiller à ce que sa lecture soit confortable. Et cela est particulièrement difficile lorsque l'on sait que les différents utilisateurs d'un même site n'utilisent pas le même navigateur par exemple. Cette problématique réapparaît lorsque l'on se penche sur les différents écrans par lesquels un utilisateur aimerait accéder à notre site. C'est pour cela que l'on va œuvrer à rendre nos site **responsive**, c’est-à-dire que l’on va faire en sorte qu’ils s’adaptent eux même à chaque taille d’écran. Ainsi, lorsque l'on construit la structure d'un site web, il est important de se poser la question de son apparence en fonction des différentes résolutions d'écran. ====Les Media Queries==== Les media queries sont des règles à appliquer pour changer le design d'un site en fonction des caractéristiques de l'écran. ===== Bootstrap ===== Bootstrap est une boite à outils comprenant plusieurs modules et permettant de faire du responsive assez facilement. ==== Installation de Bootstrap ==== === Installation rapide (via CDN) RECOMMANDEE LORS DE LA FORMA === Pour aller plus vite, on vous conseille, pour cette séance" d'utiliser Bootstrap et jQuery via CDN. Il s'agit tout simplement d'une lien que vous allez ajouter dans votre fichier HTML. Titre de ma page

Ma super page

Le fait de mettre les balises javascript à la fin du corps de la page et non dans le head permet de charger le contenu plus rapidement et donc de donner une impression de rapidité supplémentaire au visiteur. ==== La grille ==== Bootstrap permet de découper facilement le contenu pour le positionner sur la page. Pour cela il y a un système de grille, dont le contenu peut s'ajuster facilement selon la taille de l'écran de l'utilisateur. La grille de Bootstrap est divisée en lignes (**row**) qui comprend 12 colonnes (**col**). Par exemple :
.col-md
.col-md
.col-md
.col-md
.col-md
.col-md
.col-md
.col-md
.col-md
.col-md
.col-md
.col-md
.col-md-8
.col-md-4
.col-md
.col-md
.col-md
.col-md
.col-md
produira le visuel suivant : {{:formations:gridbootstrap.png|}} On remarque que si la taille des colonnes n'est pas spécifiée celles-ci prendront la taille adéquate automatiquement. Pour former une ligne complète, il suffit donc que la somme des valeurs des **col** fasse 12. * Si la somme **dépasse 12** alors le dernier bloc sera passé à la ligne. * si la somme est **inférieure à 12** alors les blocs n'ocuperont pas toute la ligne. Dans l'exemple, le **md** de col-**md**-X signifie **medium device**. Dès que la taille de l'écran passe en dessous de ce que bootstrap considère comme un medium device, l'affichage se fait en ligne au lieu d'en colonne. Cette caractérisque permet d'organiser simplement les éléments selon la taille du device. Pour BS5, la dernière version, les tailles d'écran sont définies comme ça : {{ :formations:capture_d_ecran_du_2022-10-17_17-38-32.png?nolink |}} === Documentations === Pour en savoir plus sur la grille, voir les documentations : * [[https://getbootstrap.com/docs/5.3/layout/grid|Bootstrap 5.3]] ==== La Navbar ==== A partir de maintenant on ne parlera que de Bootstrap 4. Pour BS3 il faut se référer à la documentation directement. La Navbar (navigation bar) est la barre en haut qu'on voit sur la plupart des sites et qui contient les liens vers les différentes parties d'un site web. Bootstrap intègre une Navbar responsive de base avec quelques options. === Exemples === == Navbar de base avec un logo == == Navbar avec des liens == === Documentation === Voir ici : https://getbootstrap.com/docs/5.3/components/navbar/ ==== Modal ==== Le modal est une petite fenêtre qui peut s'ouvrir sur une page, pour par exemple afficher un formulaire, afficher des informations supplémentaires. Le Modal est une fonctionnalité qui nécéssite du javascript normalement, mais avec Bootstrap on peut l'utiliser sans. === Utilisation === Il faut tout d'abord créer le bloc Modal lui-même. Celui-ci sera caché au début. Il y a beaucoup de code, mais ce qu'il faut remarquer c'est l'id sur la première ligne (**id="exampleModal"**), le titre : ''

Modal Title/h1>'', et le corps (contenu de ''div class="modal-body"''). Le reste du code consitue le corps du Modal tel que défini par Bootstrap. Ensuite pour ouvrir le modal, il faut placer un bouton : Ici les attributs font toute la fonctionnalité : * ''data-bs-toggle="modal"'' permet de dire que ce bouton doit ouvrir le modal * ''data-bs-target="#exampleModal"'' permet d'indiquer quel modal est concerné. (ID exampleModal) === Documentation === Voir ici : https://getbootstrap.com/docs/5.3/components/modal/ ==== Les autres composants ==== Bootstrap dispose d'un grand nombre de composants. Ces 3 exemples ne sont qu'une petite partie des possibilités qu'offre BS5. Il est possible de tous les trouver dans la section Components de la [[https://getbootstrap.com/docs/5.3/getting-started/introduction/|documentation]]. ===== Application : suite du CV ===== Normalement votre site perso doit en être à la [[formations:devweb_1#tp_cv_svp|fin de la pratique de la formation Devweb 1]]. ==== Architecture conseillée ==== Avant de continuer nous allons nettoyer un peu les fichiers de votre site, et définir quelles pages nous allons faire. Nous allons organiser les fichiers comme suit : * Les fichiers css dans un dossier **css/** * Les images dans un dossier **images/** css/ └── style.css images/ └── portrait.jpg index.html Si ce n'est pas déjà fait, mettre tout le CSS contenu dans le fichier html dans un fichier **css/style.css**. Pour lier le fichier CSS (dans la balise '''') : Pour les pages, on peut commencer par celles-ci : * Une page d'accueil, **index.html** * Une page de CV, mais remaniée, **cv.html** * Une galerie d'images pour les photos de loutre, **galerie.html** * Et une page pour parler de vos goûts musicaux et de votre musique préférée de JuL, **musique.html** ==== Une belle page d'accueil ==== Nous allons commencer par réaliser notre page d'accueil, qui sera assez simple, et qui pourra servir de "template" pour la création des autres pages. En suivant les exemples ci-dessus, on va mettre : * Une Navbar avec des liens pointant vers les autres pages * Un corps de page indiquant le contenu du site * Un modal apparaîssant sur un lien de la navbar avec les informations de contact === La Navbar === Pour rappel, les liens doivent pointer vers les pages suivantes : * Nom du site : **index.html** * CV : **cv.html** * Galerie : **galerie.html** * Musique : **musique.html** Le code suivant est un exemple d'implémentation de ces liens : === Le Modal de contact === On va intégrer un modal avec les informations suivantes : * Nom/prénom * Titre (étudiant à centrale Marseille par exemple) * Adresse mail * Numéro de téléphone * Un QR code contenant les informations de contact (à générer par exemple sur https://fr.qr-code-generator.com/) Pour un visuel de ce genre : {{ :formations:contactmodal.png?direct |}} Le code de ce visuel : Sans oublier le lien à ajouter dans la navbar : === Le corps du site === Un petit texte de bienvenue, basé sur l'utilisation de la grille !

Bienvenue sur mon site perso

J'aime bien le poisson, et le GInfo !

=== La page au complet === Titre de ma page

Bienvenue sur mon site perso

J'aime bien le poisson, et le GInfo !

==== Retoucher un peu le CV ==== Première étape : appliquer le même design que la page d'accueil à la page du CV. ==== La gallerie d'images ==== Voir [[https://getbootstrap.com/docs/5.3/components/carousel/#with-controls|le carousel bootstrap]] ==== La page musique ==== Pour intégrer une vidéo youtube : **Partager -> Intégrer** Exemple : ---- Cette formation a été réalisée par [[user:rgrondin|Romain GRONDIN]] et [[user:talaei|Tina ALAEI]].