JavaScript 切换图片

JavaScript 切换图片

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>图片切换</title>
    <style>
        .box {
            /* border: 3px solid red; */
            /* width: 500px; */
            width: 500px;
            margin: 0px auto;
            position: relative;

            overflow: hidden;
        }
        .container {
            /* width: calc(500px*2); */
            width: 200%;
            overflow: hidden;

            /* position: relative;
            left: -500px; */

            transition: transform 1s;
            /* transform: translateX(-500px); */
        }
        .container img {
            width: 50%;
            float: left;
        }
        .btn-group {
            position: absolute;
            bottom: 10px;
            background: red;
            left: 0;
            right: 0;

            display: flex;
            justify-content: space-around;
        }
    </style>
</head>
<body>
    <div class="box">
        <div class="container">
            <img src="img/01.jpg" alt="">
            <img src="img/02.jpg" alt="">

        </div>

        <div class="btn-group">
            <button type="button">按钮1</button>
            <button type="button">按钮2</button>
        </div>
    </div>

    <script>
       var btnElements = document.getElementsByClassName("btn-group")[0].getElementsByTagName("button");
        
        console.log(btnElements);
        var container = document.getElementsByClassName("container")[0];

        // 没有单位,获取大小
        var boxWidth = document.getElementsByClassName("box")[0].clientWidth;
        console.log(boxWidth);

        for(var i = 0; i < btnElements.length; i++) {
            // 自定义一个下标
            btnElements[i].index = i;
            btnElements[i].onclick = function(){
                console.log(this.index);
                // 通过this找下标关系
                var offsetValue = this.index * -boxWidth;
                container.style.transform = "translateX("+offsetValue+"px)";
            }
        }
    </script>
</body>
</html>

点击按钮二切换图片

点击按钮一再次切换图片

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值