Maison >interface Web >tutoriel CSS >Comment adapter une image à la fenêtre du navigateur ?

Comment adapter une image à la fenêtre du navigateur ?

DDD
DDDoriginal
2024-10-30 06:29:27569parcourir

How to Make an Image Fit the Browser Window?

Comment adapter une image à la fenêtre du navigateur : un guide complet

Dans le domaine du développement Web, afficher des images de manière transparente dans le navigateur la fenêtre pose un défi unique. Déterminer la taille appropriée d'une image pour s'adapter à la fois à la fenêtre du navigateur et aux dimensions de l'image reste un dilemme courant. Cet article explore les subtilités du redimensionnement d'une image pour l'adapter efficacement à la fenêtre du navigateur, en abordant de manière exhaustive les subtilités impliquées.

Objectifs du redimensionnement d'image

Pour parvenir à une intégration harmonieuse des images dans la mise en page Web, nous devons satisfaire aux critères suivants :

  • Les dimensions de la fenêtre du navigateur, souvent inconnues, ne doivent pas déterminer la taille de l'image.
  • Dimensions originales inconnues de l'image ne doit pas gêner le processus de redimensionnement.
  • L'image doit conserver ses proportions, en préservant ses proportions d'origine.
  • L'image doit être affichée entièrement dans la fenêtre, sans recadrage ni distorsion.
  • Les barres de défilement ne sont pas souhaitables et ne doivent pas apparaître si l'image s'adapte à la fenêtre.
  • L'image doit répondre dynamiquement aux changements dans les dimensions de la fenêtre, remplissant l'espace disponible sans dépasser sa taille d'origine.

Solution CSS uniquement

Pour ceux qui recherchent une solution CSS pure, le code suivant centre et redimensionne gracieusement l'image en fonction des dimensions de la fenêtre du navigateur :

<code class="html"><html>
<head>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .imgbox {
            display: grid;
            height: 100%;
        }
        .center-fit {
            max-width: 100%;
            max-height: 100vh;
            margin: auto;
        }
    </style>
</head>
<body>
<div class="imgbox">
    <img class="center-fit" src='pic.png'>
</div>
</body>
</html></code>

Solution basée sur jQuery

Alternativement, cette solution basée sur jQuery garantit que le conteneur d'image, le corps dans ce cas, a une hauteur égale à la hauteur de la fenêtre du navigateur, permettant ainsi la taille maximale de l'image. -hauteur pour fonctionner comme prévu :

<code class="html"><!DOCTYPE html>
<html>
<head>
    <style>
        * {
            padding: 0;
            margin: 0;
        }
        .fit {
            max-width: 100%;
            max-height: 100%;
        }
        .center {
            display: block;
            margin: auto;
        }
    </style>
</head>
<body>

<img class="center fit" src="pic.jpg">

<script src="http://code.jquery.com/jquery-latest.js"></script>
<script type="text/javascript" language="JavaScript">
    function set_body_height() {
        $('body').height($(window).height());
    }
    $(document).ready(function() {
        $(window).bind('resize', set_body_height);
        set_body_height();
    });
</script>

</body>
</html></code>

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn