zoukankan      html  css  js  c++  java
  • 缓动动画添加回调函数

    一 缓动动画添加回调函数

    1)注意实现

    回调函数调用的位置:定时器结束的位置。

    2)代码实现

    <!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>
            span {
                position: absolute;
                display: block;
                top: 200px;
                 150px;
                height: 150px;
                background-color: purple;
            }
        </style>
    </head>
    <body>
    <button id="btn">span到800以后执行回调变成红色</button>
    <span></span>
    <script>
        //1 动画函数 第三个参数是接收回调函数的形参
        function animate(object,target,callback) {
            clearInterval(object.timer);
            object.timer = setInterval(function () {
                var step = (target - object.offsetLeft)/10;
                step = step > 0 ? Math.ceil(step) : Math.floor(step);//如果正值就往大取整 如果是负值就往小取整
                if (object.offsetLeft == target) {
                    clearInterval(object.timer);
                    //3 在定时器结束后 执行回调函数
                    if (callback) {
                        callback();
                    }
                }
                object.style.left = object.offsetLeft + step + 'px';
            },15);
        }
        var span = document.querySelector('span');
        var btn = document.querySelector('#btn');
        btn.onclick = function(){
            //2 在调用动画函数的时候 把回调函数作为实参传递过去
            animate(span,800,function () {
                span.style.backgroundColor = 'red';
            });
        }
    </script>
    </body>
    </html>

    二 把动画函数封装到单独JS文件中

    js动画文件

    //1 动画函数 第三个参数是接收回调函数的形参
    function animate(object,target,callback) {
        clearInterval(object.timer);
        object.timer = setInterval(function () {
            var step = (target - object.offsetLeft)/10;
            step = step > 0 ? Math.ceil(step) : Math.floor(step);//如果正值就往大取整 如果是负值就往小取整
            if (object.offsetLeft == target) {
                clearInterval(object.timer);
                //3 在定时器结束后 执行回调函数
                if (callback) {
                    callback();
                }
            }
            object.style.left = object.offsetLeft + step + 'px';
        },15);
    }

    HTML页面

    <!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>
            .sliderbar {
                position: fixed;
                right: 0;
                bottom: 100px;
                 40px;
                height: 40px;
                text-align: center;
                line-height: 40px;
                cursor: pointer;
                color: #fff;
            }
            .con {
                position: absolute;
                left: 0;
                top: 0;
                 200px;
                height: 40px;
                background-color: purple;
                z-index: -1;
            }
        </style>
        <script src="animate.js"></script>
    </head>
    <body>
    <div class="sliderbar">
        <span>←</span>
        <div class="con">问题反馈</div>
    </div>
    <script>
        //当鼠标经过sliderbar con盒子滑动到左侧
        //当鼠标离开sliderbar con盒子滑动到右侧
        var sliderbar = document.querySelector('.sliderbar');
        var con = document.querySelector('.con');
        console.log(sliderbar,con);
        //鼠标经过事件
        sliderbar.addEventListener('mouseenter',function () {
            animate(con,-160,function () {
                //回调函数:当动画执行完毕就把 ← 改为 →
                sliderbar.children[0].innerHTML = '';
            });
        });
        //鼠标离开事件
        sliderbar.addEventListener('mouseleave',function () {
            animate(con,0,function () {
                //回调函数:当动画执行完毕就把 → 改为 ←
                sliderbar.children[0].innerHTML = '';
            });
        });
    </script>
    </body>
    </html>

    回调函数

    //1 函数可以作为一个参数

    //2 将a函数作为参数传到b函数里面,当b函数执行完之后,再执行传进来的函数a,这个过程就叫做回调
  • 相关阅读:
    Linq与Lambda,神一般的工作效率
    svn和git孰优孰劣
    关于C++的***5的输出问题
    POJ 3469 Dual Core CPU(最小割)
    HDU 4259 Double Dealing
    最大流Dinic算法
    HDU 4442 Physical Examination(2012年金华赛区现场赛A题)
    int ,long , long long类型的范围
    POJ 1679 The Unique MST(判断最小生成树是否唯一)
    HDU 4280 Island Transport(网络流)
  • 原文地址:https://www.cnblogs.com/fuyunlin/p/14462161.html
Copyright © 2011-2022 走看看