纯css简单轮播图练习/自动手动切换(实现点击切换非按钮)

 今天用css做一个简单的轮播图练习,效果如图watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA55m95LqR5aW95oeS,size_20,color_FFFFFF,t_70,g_se,x_16

点击切换图片

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA55m95LqR5aW95oeS,size_20,color_FFFFFF,t_70,g_se,x_16

这里也定义了自动切换的动画aa1   可以实现自动的动画,这里注释掉了,可以打开实现自动切换,并注释掉三个按钮label。

同时打开动画和按钮的切换会有点小问题,大概是我的方法不对,也请大佬指点。

这里采用的类似雪碧图的方法,隐藏溢出的内容通过点击修改位置达到切换图片的效果。

 源码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
             margin: 0;
             padding: 0;
           }
           body{
               background: linear-gradient(pink, rgb(216, 102, 102) ,rgb(205, 224, 98));
         
          
           }
          .out{
              margin: 50vh auto;
              width: 800px;
              overflow: hidden;
              position: relative;
              /* border: px solid red; */
         
          }
        ul{
            list-style: none;
            width: 2400px;
            background-color: aqua;
         
            /* animation: aa1 infinite 2s steps(3); */
         

         

        }
        input{
            display: none;
        }
        ul>li{
            background-color: bisque;
            width: 800px;
            height: 400px;
          
            line-height: 400px;
            text-align: center;
            float: left;
            
        }
        ul li:nth-child(1){
            background-color: aquamarine;
            background: url(./img/城市.jpg) no-repeat;
            background-size: cover;

        }
        ul li:nth-child(2){
            background-color: rgb(199, 197, 55);
            background: url(./img/beij.jpg) no-repeat;
            background-size: cover;


        }
        ul li:nth-child(3){
            background-color: rgb(17, 216, 50);
            background: url(./img/prac.jpg) no-repeat;
            background-size: cover;


        }
        .out label{
            border-radius: 50%;
            position: absolute;
            background-color: aliceblue;
            width: 20px;
            height: 20px;
            top: 80%;
            cursor: pointer;
           
           
          
        }
        .out label[for="button1"]{
            left: 35%;
        }
        .out label[for="button2"]{
            left: 45%;
        }
        .out label[for="button3"]{
            left: 55%;
        }
        .out input#button1:checked~ul{
            margin-left: 0px;
            transition:  1s;
        }
        .out input#button2:checked~ul{
            margin-left: -800px;
            transition:  1s;
        }
        .out input#button3:checked~ul{
            margin-left: -1600px;
            transition: 1s;
        }
        .out label:hover{
            border: 1px solid rgb(231, 135, 135);
            box-shadow: rgb(17, 216, 50);
            
        }
        .out input#button1:checked~label[for="button1"]{
            background-color: rgb(217, 231, 20);
        }
        .out input#button2:checked~label[for="button2"]{
            background-color: rgb(220, 235, 20);
        }
        .out input#button3:checked~label[for="button3"]{
            background-color: rgb(229, 233, 27);
        }
      
     

       
        @keyframes aa1{
          
            to{
                margin-left: -2400px;

            }
        }
        
        
    


           
    </style>
</head>
<body>
    <div class="out">
        <input type="radio" name="picture" id="button1"  checked>
        <label for="button1"></label>

        <input type="radio" name="picture" id="button2">
        <label for="button2"></label>

        <input type="radio" name="picture" id="button3">
        <label for="button3"></label>
     



        <ul>
            <li></li>
            <li></li>
            <li></li>
        </ul>


    </div>
</body>
</html>

  • 4
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值