使用JavaScript 实现简单的移动和缓动的动画效果

简介: 学习JavaScript 实现简单的移动和缓动的动画效果。

目录


一、H5的简单布局


二、css的布局


三、获取元素


四、使用js来实现‘盒子’移动


效果展示


五、使用js来实现缓动效果


效果展示


六、完整代码评论区自取


一、H5的简单布局

<div class="box box1"></div>
  <div class="box box2"></div>


二、css的布局

简易的布局出两个不同颜色的‘盒子’。

<style type="text/css">
    *{
    padding:0px;
    margin:0px;
    }
   .box{
    width: 200px;
    height: 200px;
    background: blue;
    position: absolute;
    left:0px
   }
   .box2{
    background: red;
    margin-top: 210px;
   }
   </style>


三、获取元素

var box1 = document.querySelector('.box1');
  var box2 = document.querySelector('.box2');


四、使用js来实现‘盒子’移动


可以使用函数封装,来实现,修改调用,不需要在代码中修改,可以减少出错的几率。

function myRun(box,h1,h2){  //封装函数
var myInter = setInterval(function(){
var offsetLeft = box.offsetLeft;
var num = h1;     //每次都移动h1个像素
var target = h2;  //一共移动的距离
if(offsetLeft==target){  //通过if来判断,到达了设定距离,就会删除间隔函数
  clearInterval(myInter);
  }else{
  box.style.left = offsetLeft+num+'px';//没有达到距离,一直赋值给‘盒子’左边距
    }
  },1000)}
    box1.onclick=function(){
    myRun(this,50,200); } //给‘盒子’设计点击事件,点击才会出现移动,this指向box1,里面是所调用的值,可以直接在里面修改,移动一次的距离,一共移动的距离


         

效果展示

微信图片_20220926230553.gif


五、使用js来实现缓动效果

依旧可以使用函数来封装,达到简洁的效果


大致代码与js移动相同,中间判断与上文稍微有些不同,其中的含义是,第一次移动取移动距离的十分之一,接下来的每一次移动,都是取省下来还剩多少距离的十分之一,取整是为了,在无线接近于所设置的距离可以移动。

function move(obj,sum){
                var liLi = setInterval(function(){
                    var offsetLeft =obj.offsetLeft;
                    var num  = (sum - offsetLeft)/10;
                    num > 0 ?  Math.ceil(num):Math.floor(num);
                    if(offsetLeft==sum){
                        clearInterval(liLi);
                    }else{
                        obj.style.left = offsetLeft+num+'px';
                    }
                },1000)
             }   box2.onclick=function(){
                    move(this,200);
            }


效果展示

微信图片_20220926230611.gif



相关文章
|
7月前
|
前端开发 JavaScript UED
使用JavaScript实现动画效果
【4月更文挑战第21天】使用JavaScript实现动画效果
89 10
|
1月前
|
Web App开发 前端开发 JavaScript
在 CSS3 动画中添加缓动效果时,需要注意哪些问题?
在 CSS3 动画中添加缓动效果时,需要注意哪些问题?
170 64
|
1月前
|
前端开发 JavaScript
如何在 CSS3 动画中添加多个缓动效果?
如何在 CSS3 动画中添加多个缓动效果?
48 11
|
1月前
|
JavaScript 前端开发
CSS3 动画和 JavaScript 动画的性能比较
具体的性能表现还会受到许多因素的影响,如动画的复杂程度、浏览器的性能、设备的硬件条件等。在实际应用中,需要根据具体情况选择合适的动画技术。
|
1月前
|
前端开发 JavaScript
如何在 CSS3 动画中添加缓动效果?
在上述示例中,页面中有一个蓝色的方块元素和几个按钮,点击不同的按钮可以为方块的移动动画设置不同的缓动效果。通过JavaScript获取方块元素,根据用户点击按钮传递的缓动函数值,修改方块的`transitionTimingFunction`属性,从而实现动态切换缓动效果的功能。每次点击按钮后,方块会向右移动100px,并在1秒后回到初始位置,以便用户观察不同缓动效果下的动画表现。
54 1
|
5月前
|
前端开发 JavaScript UED
使用JavaScript实现滑动动画的几种方法
使用JavaScript实现滑动动画的几种方法
|
7月前
|
Web App开发 前端开发 JavaScript
大话 JavaScript 动画
大话 JavaScript 动画
59 1
|
7月前
|
JavaScript 前端开发
jsjs原生 JavaScript轮播图 渐变淡入淡出
jsjs原生 JavaScript轮播图 渐变淡入淡出
|
前端开发 UED
CSS 支持动画效果,可以通过关键帧动画或过渡动画实现动态效果。具体案例解析
CSS 支持动画效果,可以通过关键帧动画或过渡动画实现动态效果。具体案例解析
108 1
|
移动开发 JavaScript 前端开发
使用JavaScript 实现简单的移动和缓动的动画效果
学习使用JavaScript 实现简单的移动和缓动的动画效果。
211 0