原生JS实现旋转木马轮播图特效

更新日期: 2019-11-27阅读: 3.6k标签: 特效

大概是这个样子:


首先来简单布局一下(emm...随便弄一下吧,反正主要是用js来整的)

<!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>
    <script src="js/index.js"></script>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        ul, li {
            list-style: none;
        }
        .wrap {
            margin: 0 auto;
            width: 1050px;
        }
        .slider {
            position: relative;
            margin: 50px auto;
            height: 400px;
        }
        .slider li {
            position: absolute;
        }
        .slider li img {
            width: 100%;
        }
        .slider .arrow-l,
        .slider .arrow-r{
            position: absolute;
            top: 0;
            display: none;
            width: 80px;
            height: 400px;
            background-size: 80px;
            cursor: pointer;
            opacity: 0.8;
            z-index: 99;
        }
        .arrow-r {
            right: 80px;
            background: url(img/next.png) no-repeat 0;
        }
        .arrow-l {
            left: 80px;
            background: url(img/prev.png) no-repeat 0;
        }
    </style>
</head>
<body>
    <div class="wrap">
        <div class="slider">
            <ul>
                <li><img src="img/img1.jpg" alt=""></li>
                <li><img src="img/img2.jpg" alt=""></li>
                <li><img src="img/img3.jpg" alt=""></li>
                <li><img src="img/img4.jpg" alt=""></li>
                <li><img src="img/img5.jpg" alt=""></li>
            </ul>
            <div class="arrows">
                <i class="arrow arrow-l"></i>
                <i class="arrow arrow-r"></i>
            </div>
        </div>
    </div>
</body>
</html>

下边来进入主要部分

其实主要就是动画函数的封装以及对数组的改变

动画函数部分的注释,博主的上一篇博客有写:原生JS实现动画函数的封装。这里就不重复啦~

将图片相关样式(大小、定位、透明度等)存放到arr数组里。

当用户点击左右箭头时,让数组进行相应变化(如果点击右箭头,就删除数组最后那个元素,把它添加到最前边;如果点击左箭头,就删除数组最前边那个元素,把它添加到最后边),改变完数组再调用一下move()函数(让图片轮播)

详细代码如下

window.addEventListener("load", function() {
    var arr = [
        {   // 1
            width: 450,
            top: 60,
            left: 0,
            opacity: 40,
            zIndex: 2
        },
        {   // 2
            width: 550,
            top: 30,
            left: 100,
            opacity: 70,
            zIndex: 3
        },
        {   // 3  中间图片
            width: 650,
            top: 0,
            left: 200,
            opacity: 100,
            zIndex: 4
        },
        {   // 4
            width: 550,
            top: 30,
            left: 400,
            opacity: 70,
            zIndex: 3
        },
        {   // 5
            width: 450,
            top: 60,
            left: 600,
            opacity: 40,
            zIndex: 2
        }
    ];
    var slider = document.querySelector(".slider");
    var lis = slider.querySelectorAll("li");
    var arrow_l = slider.querySelector(".arrow-l");
    var arrow_r = slider.querySelector(".arrow-r");

    // 鼠标移入移出箭头显示隐藏
    slider.addEventListener("mouseover", function() {
        arrow_l.style.display = 'block';
        arrow_r.style.display = 'block';
    });
    slider.addEventListener("mouseout", function() {
        arrow_l.style.display = 'none';
        arrow_r.style.display = 'none';
    });
    
    var flag = true; // flag节流阀 为了解决点击过快而产生bug
    move(); // 先调用一下,为了刚打开浏览器时渲染页面

    // 点击左右箭头轮播图片
    arrow_r.addEventListener("click", function() {
        if(flag) {
            flag = false; // 关闭节流阀 等到动画结束了才能继续执行点击操作
            arr.unshift(arr.pop());  // 将数组最后边的元素删除,添加到最前边
            move();  // 轮播图片
        }
    });
    arrow_l.addEventListener("click", function() {
        if(flag) {
            flag = false;
            arr.push(arr.shift());  // 将数组最前边的元素删除,添加到最后边
            move();
        }
    });

    // 让每个图片执行动画
    function move() {
        for(var i = 0; i < lis.length; i++) {
            animate(lis[i], arr[i], function() {
                flag = true;  // 回调函数,当动画执行完 再把节流阀打开
            });
        }
    }
    // 动画函数
    function animate(obj, json, callback) {
        clearInterval(obj.timer);
        obj.timer = setInterval(function() {
            var bool = true;
            for(var attr in json) {
                var icur = 0;
                if(attr == 'opacity') {
                    icur = Math.round(parseFloat(getStyle(obj, attr)) * 100);
                } else {
                    icur = parseInt(getStyle(obj, attr));
                }
                var speed = (json[attr] - icur) / 10;
                speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
                if(icur != json[attr]) {
                    bool = false;
                }
                if(attr == 'opacity') {
                    obj.style.filter = 'alpha(opacity = '+ (icur + speed) +')';
                    obj.style.opacity = (icur + speed) / 100;
                } else if(attr == 'zIndex') {
                    obj.style.zIndex = json[attr];
                } else {
                    obj.style[attr] = icur + speed + 'px';
                }
            }
            if(bool) {
                clearInterval(obj.timer);
                callback && callback();
            }
        },15);
    }
    // 获取属性函数 
    function getStyle(obj, attr) {
        if(obj.currentStyle){   //IE浏览器
            return obj.currentStyle[attr];
        }else{    //chrome、firefox等浏览器
            return getComputedStyle(obj,null)[attr];
        }
    }
});

原文:https://www.cnblogs.com/sunyan-blog/p/12104696.html

链接: https://www.fly63.com/article/detial/7073

也许vue+css3做交互特效更简单

关于vue+css3开发的特效,以及和javascript+css3的对比,就说到这里了,希望这三个小实例,能帮到大家了解下应该怎么使用vue+css3开发特效的。

纯 CSS 创作出平滑的层叠海浪特效

这里的波浪只是侧面的,利用几个平面一部分弧旋转得到。定义 dom,容器中包含一行文本和3条做海浪特效的 <span>,设置容器,文字样式,制作海浪动画效果

js实现图片放大镜特效

在平时网上商城购物时,我们能够通过放大镜效果来使我们看图片能够更加的清楚,今天我就来给大家分享一下我学习的放大镜特效

基于 HTML5 Canvas 实现的文字动画特效

文字是网页中最基本的元素,一般我们在网页上都是展示的静态文字,但是就效果来说,还是比较枯燥的。文字淡入淡出的动画效果在项目中非常实用,如果有某些关键的文字,可以通过这种动态的效果来提醒用户阅读

只需三步,实时多边形折射

在本教程中,您将学习如何使用Three.js在三个步骤中使对象看起来像玻璃。渲染3D对象时,无论使用某种3D软件还是使用WebGL进行实时显示,始终都必须为其分配材料以使其可见并具有所需的外观。

纯CSS3仿网易云孤独星球特效

今天收听网易云音乐时看到孤独星球的特效,于是就顺手搬到这里了。孤独星球特效本身没有什么难点,但如果要加入音轨控制星球运动频率就有点麻烦了

纯css3实现二维码扫描特效

第一步,实现网格背景:第二部实现扫码线以及渐变背景特效,四角特效就是四个宽高相等的正方形,分别设置边框即可。设置扫描动画

canvas+js实现数字雨特效【字符下落特效】

用dropLine这个列表来记录绘制过程,dropLine[i]的意义是表示在第i列,第dropLine[i]行绘制!filltext()是canvas中的方法,这里的三个参数分别对应:内容,横坐标,纵坐标。

纯js时钟特效

电子时钟是网上常见的功能,在学习date对象和定时器功能时,来完成一个电子时钟的制作是不错的选择。学习本教程之前,读者需要具备html和css技能,同时需要有简单的javascript基础。

css按钮悬停特效

本文给大家介绍几款按钮的鼠标悬停效果,是纯CSS实现的,鼠标移上按钮后,按钮会随之发生变化。这种效果使用非常广泛,非常多的网页都用上了这个效果。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!