【JavaScript-动画原理】如何使用js进行动画效果的实现

本人编程小白,个人理解可能不到位望谅解


 代码样式如上:

前言

今天主要来说的就是动画,动画对于大家来说都不陌生,但是作为前端人员来说一般情况使用的都是css动画,今天要使用的是js的动画。

一、首先写入HTML和CSS的代码

二、使用步骤

1.编写HTML部分

代码如下:

  <!--点击按钮移动到距离页面左侧500px -->
    <button class="btn500">点击动500</button>
    <!--点击按钮移动到距离页面左侧800px -->
    <button class="btn800">点击动800</button>
    <!--打开页面自动移动的盒子 -->
    <div></div>
    <!--点击移动的盒子 -->
    <span>是小韩呀</span>

2.编写CSS部分

代码如下:

 <style>
        div {
            width: 100px;
            height: 100px;
            background-color: pink;
            /*一定要加定位*/
            position: absolute;
            left: 0;
        }
        
        span {
            width: 150px;
            height: 150px;
            background-color: blueviolet;
            display: block;
            /*一定要加定位*/
            position: absolute;
            left: 0;
            top: 200px;
        }
    </style>

3.编写JS部分

代码如下:

<script>
        // 封装函数
        // 添加定时器
        function animate(obj, target, callback) {
            //callback=function(){} 调用 callback()
            clearInterval(obj.timer);
            obj.timer = setInterval(function() {
                // 设置缓动动画
                // 缓动动画原理(目标值-现在的长度)/10 做为每次移动的距离 步长
                var step = (target - obj.offsetLeft) / 10;
                // 左右取整,为了代码移动位置的准确性
                step = step > 0 ? Math.ceil(step) : Math.floor(step);
                if (obj.offsetLeft == target) {
                    clearInterval(obj.timer);
                    //回调函数
                    callback();
                }
                obj.style.left = obj.offsetLeft + step + 'px';
            }, 30);
        }
        // 获取元素
        var div = document.querySelector('div');
        var span = document.querySelector('span');
        var btn500 = document.querySelector('.btn500');
        var btn800 = document.querySelector('.btn800');
        //调用函数,移动到500px变换颜色 执行完毕,执行回调函数
        animate(div, 600);
        btn500.addEventListener('click', function() {
            animate(span, 500, function() {
                span.style.backgroundColor = 'blue';
            });


        });
        //调用函数,移动到800px变换颜色 执行完毕,执行回调函数
        btn800.addEventListener('click', function() {
            animate(span, 800, function() {
                span.style.backgroundColor = 'red';
            });

        });
    </script>


总结

对于JS动画来说其实主要注意几点,获得盒子当前位置,让盒子在当前位置加上1个移动距离,利用定时器不断重复这个操作,加一个结束定时器的条件,注意该元素需要添加定位,才能使用element.style.left

然后进行动画函数的封装,给不同的元素添加定时器,为了效果的美观添加缓动动画,最后再给动画添加回调函数,让他可以一直执行。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用HTML5中的Canvas元素和JavaScript实现写字动画效果。具体实现步骤如下: 1. 创建一个Canvas元素,并设置它的宽度和高度。 2. 使用JavaScript获取Canvas的上下文对象。 3. 设置字体、颜色、阴影等样式属性。 4. 使用Canvas的beginPath()方法开始绘制路径。 5. 使用Canvas的moveTo()和lineTo()方法绘制字母路径。 6. 使用Canvas的stroke()方法绘制路径。 7. 使用JavaScript的定时器函数setInterval()不断更新字母的位置,从而实现动画效果。 下面是一个简单的示例代码: HTML代码: ```html <canvas id="myCanvas" width="500" height="200"></canvas> ``` JavaScript代码: ```javascript // 获取Canvas元素的上下文对象 var canvas = document.getElementById("myCanvas"); var ctx = canvas.getContext("2d"); // 设置字体属性 ctx.font = "80px Arial"; ctx.fillStyle = "red"; ctx.shadowColor = "black"; ctx.shadowBlur = 10; // 定义字母路径 ctx.beginPath(); ctx.moveTo(50, 100); ctx.lineTo(100, 50); ctx.lineTo(150, 100); ctx.lineTo(200, 50); ctx.lineTo(250, 100); ctx.lineTo(250, 150); ctx.stroke(); // 定义定时器函数来更新字母位置 var x = 50; var y = 100; var dx = 5; var dy = -5; setInterval(function() { ctx.clearRect(0, 0, canvas.width, canvas.height); ctx.beginPath(); ctx.moveTo(x, y); ctx.lineTo(x+50, y-50); ctx.lineTo(x+100, y); ctx.lineTo(x+150, y-50); ctx.lineTo(x+200, y); ctx.lineTo(x+200, y+50); ctx.stroke(); x += dx; y += dy; if (x > canvas.width-200 || x < 0) { dx = -dx; } if (y > canvas.height-50 || y < 0) { dy = -dy; } }, 10); ``` 这段代码实现了一个不断移动的字母路径,可以根据需要修改字母的形状和动画效果

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值