这篇文章主要讲解了JS如何实现滑稽笑脸运动效果,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
10年积累的成都网站制作、成都做网站经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站制作后付款的网站建设流程,更有昌平免费网站建设让你可以放心的选择与我们合作。
效果演示:
(就这玩意儿,差点写崩了...)
代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>滑稽笑脸运动</title> <meta name="author" content="marinerzp"> <style> *{padding: 0;margin: 0;} html,body{ width: 100%; height: 100%; } #main{ width: 100px; height: 100px; border-radius: 50%; background:url(images/1.jpg) 0 0/100px 100px; position: absolute; left: 0; top: 0; z-index: 3; } .show{ width: 50px; height: 50px; border-radius: 50%; background-color: rgb(239, 187, 101); position: absolute; animation: disappear 1.2s ; animation-fill-mode: forwards; } @keyframes disappear{ 0%{ opacity: 1; transform:scale(1); } 100%{ opacity: 0; transform:scale(0); } } </style> </head> <body> <div id="main"> </div> <script> let Omain=document.querySelector('#main'); let MaxLeft=window.innerWidth-Omain.offsetWidth; let MaxTop=window.innerHeight-Omain.offsetHeight; window.οnresize=function(){//监听窗口大小改变事件 MaxLeft=window.innerWidth-Omain.offsetWidth; MaxTop=window.innerHeight-Omain.offsetHeight; }; /* 水平方向上:以向右为正方向 竖直方向上:以向下为正方向 */ let Vx=6;//3px/s let Vy=9;//4px/s let X=0,Y=0; ~~function move(){ X+=Vx; Y+=Vy; if (Y>=MaxTop) { Y=MaxTop; Vy=-Vy; } if (Y<=0) { Y=0; Vy=-Vy; } if (X>=MaxLeft) { X=MaxLeft; Vx=-Vx; } if (X<=0) { X=0; Vx=-Vx; } Omain.style.left=`${X}px`; Omain.style.top=`${Y}px`; createTail(X,Y);//生成拖尾 requestAnimationFrame(move); }(); function createTail(X,Y){ let node=document.createElement('p'); node.classList.add('show'); node.style.cssText=`left:${X+20}px;top:${Y+20}px`; document.body.appendChild(node); setTimeout(()=>{ document.body.removeChild(node); node=null; },1200); } </script> </body> </html>
看完上述内容,是不是对JS如何实现滑稽笑脸运动效果有进一步的了解,如果还想学习更多内容,欢迎关注创新互联行业资讯频道。
分享名称:JS如何实现滑稽笑脸运动效果
网页URL:https://www.cdcxhl.com/article36/poepsg.html
成都网站建设公司_创新互联,为您提供云服务器、网站建设、品牌网站制作、Google、网站导航、网页设计公司
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联