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

发布时间:2024-07-20 10:01

目录

一、H5的简单布局

二、css的布局

三、获取元素

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

效果展示

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

效果展示

 六、完整代码评论区自取


一、H5的简单布局

	

二、css的布局

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

		

三、获取元素

		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,里面是所调用的值,可以直接在里面修改,移动一次的距离,一共移动的距离
            

效果展示

使用JavaScript 实现简单的移动和缓动的动画效果_第1张图片

五、使用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);
            }

效果展示

 六、完整代码评论区自取

ItVuer - 免责声明 - 关于我们 - 联系我们

本网站信息来源于互联网,如有侵权请联系:561261067@qq.com

桂ICP备16001015号