首页  >  文章  >  web前端  >  纯 CSS 中的图像交换

纯 CSS 中的图像交换

Linda Hamilton
Linda Hamilton原创
2024-11-25 06:29:27790浏览

纯 CSS 中的图像交换

Image Swap in Pure CSS

Image Swap in Pure CSS

让我们在不使用 JavaScript 的情况下使用纯 CSS 创建图像交换教程。

  1. 让我们使用输入单选按钮、标签在 html 中创建一些元素。最后,我们还添加 **
    <div>
    
    
    
    <p>Let's create <strong>CSS</strong><br>
    </p>
    
    <pre class="brush:php;toolbar:false"> * {
        margin: 0;
        padding: 0;
    } 
    
    html {
        height: 100%;
        scroll-behavior: smooth;
    }
    
    body {
        display: flex;
        flex-direction: column;
        height: 100%;
        font-family: monospace;
        place-content: center;
        background-size: 100% 100%;
        background-position: 0px 0px;
        background-image: radial-gradient(18% 28% at 24% 50%, #CEFAFFFF 7%,
     #073AFF00 100%), radial-gradient(18% 28% at 18% 71%, #FFFFFF59 6%, 
    #073AFF00 100%), radial-gradient(70% 53% at 36% 76%, #73F2FFFF 0%, 
    #073AFF00 100%), radial-gradient(42% 53% at 15% 94%, #FFFFFFFF 7%,
     #073AFF00 100%), radial-gradient(42% 53% at 34% 72%, #FFFFFFFF 7%,
     #073AFF00 100%), radial-gradient(18% 28% at 35% 87%, #FFFFFFFF 7%,
     #073AFF00 100%), radial-gradient(31% 43% at 7% 98%, #FFFFFFFF 24%,
     #073AFF00 100%), radial-gradient(21% 37% at 72% 23%, #D3FF6D9C 24%,
     #073AFF00 100%), radial-gradient(35% 56% at 91% 74%, #8A4FFFF5 9%,
     #073AFF00 100%), radial-gradient(74% 86% at 67% 38%, #84d9ff 24%,
     #073AFF00 100%), linear-gradient(125deg, #4EB5FFFF 1%, #4C00FCFF 100%);
    }
    
    .wrapper {
        width: 860px;
        height: 283px;
        position: relative;
        margin: 0 auto;
    }
    
    .wrapper label {
        width: 200px;
        height: 134px;
        cursor: pointer;
        position: absolute;
        transition: 0.25s;
        border-radius: 10px;
    }
    
    .wrapper label img{
        max-width: 100%;
        height: 100%;
        border-radius: 10px;
    }
    
    .wrapper input[type="radio"] {
        padding: 5px 5px 5px 10px;
        height: 134px;
        width: 200px;
        cursor: pointer;
        position: absolute;
        z-index: -1;
        opacity: 0;
    }
    
    .wrapper input[type="radio"]+label span {
        opacity: 0;
        background: var(--bg);
        display: inline-block;
        border-radius: 7px;
        padding: 5px 0 5px 10px;
        margin-top: 5px;
        width: calc(100% - 10px);
        color: white;
    }
    
    .wrapper input[type="radio"]:checked+label span {
        opacity: 1;
        animation-delay: 1s;
        animation: fade 1s;
    }
    
    /* static positions */
    .wrapper input[type="radio"]#s1,
    .wrapper input[type="radio"]#s1+label {
        left: 0;
        top: 0;
    }
    
    .wrapper input[type="radio"]#s2,
    .wrapper input[type="radio"]#s2+label {
        left: 440px;
        top: 0;
    }
    
    .wrapper input[type="radio"]#s3,
    .wrapper input[type="radio"]#s3+label {
        left: 655px;
        top: 0;
    }
    
    .wrapper input[type="radio"]#s4,
    .wrapper input[type="radio"]#s4+label {
        left: 440px;
        top: 150px;
    }
    
    .wrapper input[type="radio"]#s5,
    .wrapper input[type="radio"]#s5+label {
        left: 655px;
        top: 150px;
    }
    
    /* onclick shows large image and caption*/
    .wrapper input[type="radio"]:checked,
    .wrapper input[type="radio"]:checked+label {
        left: 0 !important;
        top: 0 !important;
        width: 425px;
        height: 100%;
    }
    
    /* placing first item position when clickced on other thumbnails */
    .wrapper input[type="radio"]#s2:checked~#s1+label {
        left: 440px;
    }
    
    .wrapper input[type="radio"]#s3:checked~#s1+label {
        left: 660px;
    }
    
    .wrapper input[type="radio"]#s4:checked~#s1+label {
        left: 440px;
        top: 150px;
    }
    
    .wrapper input[type="radio"]#s5:checked~#s1+label {
        left: 660px;
        top: 150px;
    }
    
    @keyframes fade {
        from {
            opacity: 0;
        }
    
        to {
            opacity: 1;
        }
    }
    
    /* changing background color when clicked on thumbnails */
    .bg {
        position: fixed;
        left: 0;
        top: 0;
        width: 100vw;
        height: 100vh;
        z-index: -1;
    }
    
    .wrapper input[type="radio"]#s2:checked~.bg {
        background-image: radial-gradient(circle, rgba(238, 174, 202, 1) 0%, rgba(148, 187, 233, 1) 100%);
    }
    
    .wrapper input[type="radio"]#s3:checked~.bg {
        background-image: radial-gradient(circle, rgb(197, 218, 196) 0%, rgb(88, 167, 204) 100%);
    }
    
    .wrapper input[type="radio"]#s4:checked~.bg {
        background-image: radial-gradient(circle, rgb(238, 226, 174) 0%, rgb(177, 139, 131) 100%);
    }
    
    .wrapper input[type="radio"]#s5:checked~.bg {
        background-image: radial-gradient(circle, rgb(174, 238, 225) 0%, rgb(36, 163, 136) 100%);
    }
    

    现在,我们已经完成了静态位置的交换动画。检查下面的 gif 动画中的输出是否可以播放,否则请转到本文末尾并查看演示的 codepen 链接。

    Image Swap in Pure CSS

    现在让我们尝试使用 CSS 自定义变量来动态宽度和高度。使用自定义 css 变量非常有用,因为只需更改 2 个位置,所有尺寸(大尺寸和缩略图)包括间隙都会自动修复。让我们在 :root
    中创建变量

     :root {
         --w: 800px;
         --h: 270px;
         --m: 15px;
         --thumbw: calc(var(--w)/4 - 15px);
         --thumbh: calc(50% - var(--m));
         --top: calc(var(--h)/2 + var(--m)/2 + 0px);
     }
    

    现在忽略之前的所有 CSS 并替换为下面的 CSS。您可以在下面发现之前的 CSS 已被注释并替换为自定义变量。

    :root {
        --w: 800px;
        --h: 270px;
        --m: 15px;
        --thumbw: calc(var(--w)/4 - 15px);
        --thumbh: calc(50% - var(--m));
        --top: calc(var(--h)/2 + var(--m)/2 + 0px);
    }
    
     * {
         margin: 0;
         padding: 0;
     }
    
     html {
         height: 100%;
         scroll-behavior: smooth;
     }
    
    body {
        display: flex;
        flex-direction: column;
        height: 100%;
        font-family: monospace;
        place-content: center;
        background-size: 100% 100%;
        background-position: 0px 0px;
        background-image: radial-gradient(18% 28% at 24% 50%, #CEFAFFFF 7%,
     #073AFF00 100%), radial-gradient(18% 28% at 18% 71%, #FFFFFF59 6%, 
    #073AFF00 100%), radial-gradient(70% 53% at 36% 76%, #73F2FFFF 0%, 
    #073AFF00 100%), radial-gradient(42% 53% at 15% 94%, #FFFFFFFF 7%,
     #073AFF00 100%), radial-gradient(42% 53% at 34% 72%, #FFFFFFFF 7%,
     #073AFF00 100%), radial-gradient(18% 28% at 35% 87%, #FFFFFFFF 7%,
     #073AFF00 100%), radial-gradient(31% 43% at 7% 98%, #FFFFFFFF 24%,
     #073AFF00 100%), radial-gradient(21% 37% at 72% 23%, #D3FF6D9C 24%,
     #073AFF00 100%), radial-gradient(35% 56% at 91% 74%, #8A4FFFF5 9%,
     #073AFF00 100%), radial-gradient(74% 86% at 67% 38%, #84d9ff 24%,
     #073AFF00 100%), linear-gradient(125deg, #4EB5FFFF 1%, #4C00FCFF 100%);
    }
    
     .wrapper {
         /* width: 860px; */
         /* height: 283px; */
         width: var(--w);
         height: var(--h);
         position: relative;
         margin: 0 auto;
     }
    
     .wrapper label {
         /* width: 200px; */
         width: var(--thumbw);
         height: calc(50% - var(--m) / 2);
         cursor: pointer;
         position: absolute;
         transition: 0.25s;
         border-radius: 10px;
     }
    
     .wrapper label img,
     .wrapper label div {
         max-width: 100%;
         height: 100%;
         border-radius: 10px;
     }
    
     .wrapper input[type="radio"] {
         padding: 5px 5px 5px 10px;
          /* width: 200px; */
         /* height: 134px; */
         height: calc(50% - var(--m) / 2);
         width: var(--thumbw);
         cursor: pointer;
         position: absolute;
         z-index: -1;
         opacity: 0;
     }
    
     .wrapper input[type="radio"]+label span {
         opacity: 0;
         background: var(--bg);
         display: inline-block;
         border-radius: 7px;
         padding: 5px 0 5px 10px;
         margin-top: 5px;
         width: calc(100% - 10px);
         color: white;
     }
    
     .wrapper input[type="radio"]:checked+label span {
         opacity: 1;
         animation-delay: 1s;
         animation: fade 1s;
     }
    
     .wrapper input[type="radio"]#s1,
     .wrapper input[type="radio"]#s1+label {
         left: 0;
         top: 0;
     }
    
     .wrapper input[type="radio"]#s2,
     .wrapper input[type="radio"]#s2+label {
         /* left: 440px; */
         left: calc((var(--w)/2) + var(--m));
         top: 0;
     }
    
     .wrapper input[type="radio"]#s3,
     .wrapper input[type="radio"]#s3+label {
         /* left: 655px; */
         left: calc(var(--w)/2 + var(--thumbw) + var(--m) + 15px);
         top: 0;
     }
    
     .wrapper input[type="radio"]#s4,
     .wrapper input[type="radio"]#s4+label {
         /* left: 440px; */
          /* top: 150px; */
         left: calc((var(--w)/2) + var(--m));
         top: var(--top);
     }
    
     .wrapper input[type="radio"]#s5,
     .wrapper input[type="radio"]#s5+label {
         /* left: 655px; */
          /* top: 150px; */
         left: calc(var(--w)/2 + var(--thumbw) + var(--m) + 15px);
         top: var(--top);
     }
    
     .wrapper input[type="radio"]:checked,
     .wrapper input[type="radio"]:checked+label {
         left: 0 !important;
         top: 0 !important;
         /* width: 425px; */
         width: calc(var(--w)/2);
         height: 100%;
     }
    
     .bg {
         position: fixed;
         left: 0;
         top: 0;
         width: 100vw;
         height: 100vh;
         z-index: -1;
     }
    
     .wrapper input[type="radio"]#s2:checked~#s1+label {
         /* left: 440px; */
         left: calc((var(--w)/2) + var(--m));
     }
    
     .wrapper input[type="radio"]#s3:checked~#s1+label {
         /* left: 660px; */
         left: calc(var(--w)/2 + var(--thumbw) + var(--m) + 15px);
     }
    
     .wrapper input[type="radio"]#s4:checked~#s1+label {
         /* left: 440px; */
          /* top: 150px; */
         left: calc((var(--w)/2) + var(--m));
         top: var(--top);
     }
    
     .wrapper input[type="radio"]#s5:checked~#s1+label {
         /* left: 660px; */
          /* top: 150px; */
         left: calc(var(--w)/2 + var(--thumbw) + var(--m)*2);
         top: var(--top);
     }
    
    
     @keyframes fade {
         from {
             opacity: 0;
         }
    
         to {
             opacity: 1;
         }
     }
    
     .wrapper input[type="radio"]#s2:checked~.bg {
         background-image: radial-gradient(circle, rgba(238, 174, 202, 1) 0%, rgba(148, 187, 233, 1) 100%);
     }
    
     .wrapper input[type="radio"]#s3:checked~.bg {
         background-image: radial-gradient(circle, rgb(197, 218, 196) 0%, rgb(88, 167, 204) 100%);
     }
    
     .wrapper input[type="radio"]#s4:checked~.bg {
         background-image: radial-gradient(circle, rgb(238, 226, 174) 0%, rgb(177, 139, 131) 100%);
     }
    
     .wrapper input[type="radio"]#s5:checked~.bg {
         background-image: radial-gradient(circle, rgb(174, 238, 225) 0%, rgb(36, 163, 136) 100%);
     }
    

    现在在 :root {--w: 800px; --h: 270px;}.只需按比例更改宽度和高度即可。转到网址 https://scriptygoddess.com/resources/proportioncalc.htm 并输入:根宽度和高度,如下图所示

    Image Swap in Pure CSS

    现在输入新的宽度或高度以获得比例值。我添加了新的宽度 1000 并单击调整大小,高度为 337.5,并在 :root {--w: 1000px; --h: 337.5px;}。这就是你所要做的。您可以看到所有图像的变化 - 宽度、高度、间隙按比例增加。

    您可以在下面的codepen链接中的:root中编辑宽度和高度的值并运行。玩得开心!
    Codepen 演示

    感谢您的观看...

以上是纯 CSS 中的图像交换的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn