原生JavaScript实现动画

原生JavaScript实现动画的主要方法有setInterval()、setTimeout()以及requestAnimationFrame()1。以下是一些关于使用原生JavaScript实现动画的方法、技巧和注意事项:

  1. setInterval()和setTimeout():这两个函数可以用来创建定时器,通过设定时间间隔来实现动画效果。例如,你可以使用setInterval()每隔一定时间改变元素的样式,从而创建动画效果1

  2. requestAnimationFrame():这是一个更现代的动画API,它可以让浏览器在下次重绘之前调用你传入给它的回调函数来更新动画。这个方法在处理复杂动画或需要更高帧率的动画时非常有用2

  3. 动画与时间关联:在创建动画时,一个常见的问题是动画的速度会受到代码执行速度的影响。为了避免这个问题,你可以将动画与时间关联起来,而不是与代码执行的次数关联。这样,无论代码执行的速度如何,动画总是按照预定的速度播放1

  4. 注意事项:在使用这些方法创建动画时,需要注意的是,如果在循环中进行大量的计算或操作,可能会导致动画变慢。此外,当页面不可见或者最小化时,setInterval()和setTimeout()可能会停止运行,而requestAnimationFrame()则会继续运行1

以下是一些使用原生JavaScript实现动画的代码案例:

  1. 匀速动画:这是一个简单的匀速动画效果,使一个元素在一定时间内匀速移动到指定位置。

    function animate(element, target) {
    clearInterval(element.timer);
    element.timer = setInterval(function () {
    var current = element.offsetLeft;
    var step = (target - current) / 10;
    step = step > 0 ? Math.ceil(step) : Math.floor(step);
    current += step;
    element.style.left = current + 'px';
    if (current === target) {
    clearInterval(element.timer);
    }
    }, 20);
    }

  2. 缓动动画:这是一个简单的缓动动画效果,使一个元素在一定时间内缓动移动到指定位置。

    function animate(element, target) {
    clearInterval(element.timer);
    element.timer = setInterval(function () {
    var current = element.offsetLeft;
    var step = (target - current) / 10;
    step = step > 0 ? Math.ceil(step) : Math.floor(step);
    current += step;
    element.style.left = current + 'px';
    if (current === target) {
    clearInterval(element.timer);
    }
    }, 20);
    }

  3. 淡入淡出动画:这是一个简单的淡入淡出动画效果,使一个元素在一定时间内逐渐显示或隐藏。

    function fadeIn(element) {
    var op = 0.1; // initial opacity
    element.style.display = 'block';
    var timer = setInterval(function () {
    if (op >= 1){
    clearInterval(timer);
    }
    element.style.opacity = op;
    element.style.filter = 'alpha(opacity=' + op * 100 + ")";
    op += op * 0.1;
    }, 10);
    }

    function fadeOut(element) {
    var op = 1; // initial opacity
    var timer = setInterval(function () {
    if (op <= 0.1){
    clearInterval(timer);
    element.style.display = 'none';
    }
    element.style.opacity = op;
    element.style.filter = 'alpha(opacity=' + op * 100 + ")";
    op -= op * 0.1;
    }, 10);
    }

相关推荐
进击的尘埃36 分钟前
Vitest 自定义 Reporter 与覆盖率卡口:在 Monorepo 里搞增量覆盖率检测
javascript
进击的尘埃37 分钟前
E2E 测试里的网络层,到底该怎么 Mock?
javascript
DevUI团队1 小时前
🚀 【Angular】MateChat V20.2.2版本发布,新增8+组件,欢迎体验~
前端·javascript·人工智能
DevUI团队2 小时前
🚀 MateChat V1.11.0 震撼发布!新增工具按钮栏组件及体验问题修复,欢迎体验~
前端·javascript·人工智能
学以智用2 小时前
Vue 3 核心函数全解(组合式 API + 常用工具函数)
javascript·vue.js
滕青山2 小时前
HTTP状态查询 在线工具核心JS实现
前端·javascript·vue.js
SuperEugene2 小时前
Vue3 中后台实战:VXE-Table 从基础表格到复杂业务表格全攻略 | Vue生态精选篇
前端·javascript·vue.js
SuperEugene2 小时前
Vue3 中后台实战:Element + VXE Table 搜索表格分页完整方案 | Vue生态精选篇
前端·javascript·vue.js
gyx_这个杀手不太冷静3 小时前
OpenCode 进阶使用指南(第一章:Agent 模式)
前端·javascript·ai编程
wuhen_n3 小时前
computed 的缓存哲学:如何避免不必要的重复计算?
前端·javascript·vue.js