Maison > interface Web > tutoriel CSS > Comment s'assurer que la largeur et la hauteur de l'image sur la page maintiennent toujours un rapport de 16:9

Comment s'assurer que la largeur et la hauteur de l'image sur la page maintiennent toujours un rapport de 16:9

不言
Libérer: 2018-10-23 16:25:24
avant
6130 Les gens l'ont consulté

Le contenu de cet article explique comment conserver la largeur et la hauteur de l'image sur la page dans un rapport de 16:9. J'espère que ce sera le cas. utile pour vous.

Objectif :
J'ai rencontré le besoin de conserver les images sur la page quelle que soit la façon dont la largeur change. La largeur et la hauteur maintiennent le rapport 16:9.

Implémentation :

Méthode 1 : Il s'agit également d'une méthode plus classique, implémentée à l'aide de padding-bottom.

<!DOCTYPE html>
<html>
<head>
    <title>固定宽高比16:9</title>
    <style type="text/css">
        *{
            margin: 0px;
            padding: 0px;
         }
        .wrap{
            width:100%;
        }
        /* 16:9宽高比,则设padding-bottom:56.25% */
        /* height: 0px,防止矩形被里面的内容撑出多余的高度*/
        .box{
            width: 100vw; 
            height: 0px; 
            position: relative;
            padding-bottom: 56.25%;
            background: pink;
        }
        /* 如果需要在div里面设置内容*/
        /* 需要设置position:absolute,才能设置内容高度100%和矩形一样 */
        /*.box p{
            width: 100%;
            height: 100%;
            position: absolute;
        }*/
    </style>
</head>
<body>
<div class="wrap">
    <div class="box">
        <p>这是一个16:9的矩形</p>
    </div>
</div>
</body>
</html>
Copier après la connexion

Méthode 2 : utilisez vmin pour y parvenir.

<!DOCTYPE html>
<html>
<head>
    <title>固定宽高比16:9</title>
    <style type="text/css">
        *{
            margin: 0px;
            padding: 0px;
         }
        .wrap{
            width:100%;
        }
        /*vmin:相对于可视窗口的宽度或高度中较小的那个,被均分为100单位的vmin*/
        /*例:当宽度是300,高度是600,那么50vmin则是相对于宽度的50%*/
        .box{
            height: 56.25vmin;
            background: pink;
        }

    </style>
</head>
<body>
<div class="wrap">
    <div class="box">
        <p>这是一个16:9的矩形</p>
    </div>
</div>
</body>
</html>
Copier après la connexion

Remarque : si la largeur de l'écran est plus grande et la hauteur est plus petite, vmax peut être utilisé. Si vous devez changer à volonté, vous pouvez le contrôler via js.

Résumé :
Les deux méthodes ont leurs propres avantages et inconvénients. La première méthode : a une bonne compatibilité, le code est relativement long et il est plus difficile à comprendre. Méthode 2 : Le code est concis et facile à comprendre après avoir clarifié la définition, mais la compatibilité est relativement mauvaise. Mais qu’en est-il de la compatibilité, alors de quoi as-tu peur Hahaha ?

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!

Étiquettes associées:
source:segmentfault.com
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal