本文实例分析了JS弹性运动实现方法。分享给大家供大家参考,具体如下:

描述:像弹簧一样左右弹动,最后缓慢停下来
一、加减速运动
1.加速运动
var iSpeed=0; iSpeed++;
速度越来越快,最后冲出去
2.减速运动
var iSpeed=20; iSpeed--;
速度越来越慢,降到0后开始变负值往反方向运动
二、弹性运动
1.在目标点左边,加速;目标点右边,减速,如
if(div1.offsetLeft<300){
iSpeed=iSpeed+1; //等同iSpeed++;
}
else{
iSpeed=iSpeed-1;
}
这是最简单的弹性运动,缺陷:加速度恒定(应该根据松紧带而变)
if(div1.offsetLeft<300){
iSpeed=iSpeed+(300-div1.offsetLeft)/50;
}
else{
iSpeed=iSpeed-(div1.offsetLeft-300)/50;
}
iSpeed=iSpeed+(300-div1.offsetLeft)/50; ==>iSpeed=iSpeed+300/50-div1.offsetLeft/50;
iSpeed=iSpeed-(div1.offsetLeft-300)/50; ==>iSpeed=iSpeed-div1.offsetLeft/50+300/50;
这两个完全一样 所以不需要if/else
iSpeed+=(300-div1.offsetLeft)/50; div1.style.left=div1.offsetLeft+iSpeed+'px';
缺陷2:不会停下来(缺少摩擦力)
iSpeed+=(300-div1.offsetLeft)/50; iSpeed*=0.95; //乘一个小数,越来越小 div1.style.left=div1.offsetLeft+iSpeed+'px';
三、带摩擦力的弹性运动
比较好的组合
iSpeed+=(300-div1.offsetLeft)/5; iSpeed*=0.7;
注:var iSpeed=0;要放在定时器外面,不然每次都从0开始,加啊乘啊就没用了
四、整合好的弹性运动框架
var iSpeed=0;
var left=0;
function startMove(obj,iTarget){
clearInterval(obj.timer);
obj.timer=setInterval(function(){
iSpeed+=(iTarget-obj.offsetLeft)/5;
iSpeed*=0.7; //计算出来的速度是一个小数,如果给它取整,会一直左右移动
left+=iSpeed; //把速度存在变量里,变量是可以有小数的
if(Math.abs(iSpeed)<1 && Math.abs(left-iTarget)<1){ //因为iSpeed和left都是小数,所以永远达不到0和目标点,只能无限接近
clearInterval(obj.timer); //虽然速度最后接近于0,看似运动停止了,但定时器还一直开着,所以当速度=0并且到达目标点,关掉(只是速度=0关掉,运动到最右边准备回来那一刹那,速度=0,同理只是到达目标点关掉,一开始往右运动经过中间时会达到目标点,所以必须两者同时满足)
obj.style.left=iTarget+'px'; //小数无法完全贴合,所以最后直接让他等于目标点,一般人肉眼看不出来
}
else{
obj.style.left=left+'px'; //style.left只能是一个整数,所以每次会把小数抹掉,误差是累计的,最终累加起来就会有1-2像素,用obj.offsetLeft+iSpeed就会无法完全贴合
}
},30);
};
五、弹性运动不适用的地方
样式会过界的
比如高度,先变大后变小,如果物体本身高度很小,可能会变成负值,就不对了
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript运动效果与技巧汇总》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
# JS
# 弹性运动
# JavaScript拖拽、碰撞、重力及弹性运动实例分析
# 原生JS+CSS实现炫酷重力模拟弹跳系统的登录页面
# JavaScript模拟重力状态下抛物运动的方法
# Javascript实现重力弹跳拖拽运动效果示例
# 纯js模拟div层弹性运动的方法
# JS实现小球的弹性碰撞效果
# js实现带简单弹性运动的导航条
# js弹性势能动画之抛物线运动实例详解
# JavaScript实现重力下落与弹性效果的方法分析
# 是一个
# 减速运动
# 停下来
# 加速运动
# 都是
# 这是
# 就会
# 放在
# 相关内容
# 让他
# 不需要
# 就不
# 遍历
# 感兴趣
# 这两个
# 数据结构
# 就没
# 用了
# 给大家
# 比较好
相关文章:
如何快速生成高效建站系统源代码?
,怎么用自己头像做动态表情包?
建站为何优先选择香港服务器?
山东网站制作公司有哪些,山东大源集团官网?
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
如何在阿里云虚拟服务器快速搭建网站?
建站之星下载版如何获取与安装?
如何在Ubuntu系统下快速搭建WordPress个人网站?
表情包在线制作网站免费,表情包怎么弄?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
C++用Dijkstra(迪杰斯特拉)算法求最短路径
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
如何做网站制作流程,*游戏网站怎么搭建?
活动邀请函制作网站有哪些,活动邀请函文案?
如何快速搭建高效WAP手机网站吸引移动用户?
定制建站价位费用解析与套餐推荐全攻略
内部网站制作流程,如何建立公司内部网站?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
昆明网站制作哪家好,昆明公租房申请网上登录入口?
建站之星如何取消后台验证码生成?
如何快速选择适合个人网站的云服务器配置?
如何在阿里云高效完成企业建站全流程?
潮流网站制作头像软件下载,适合母子的网名有哪些?
公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?
小程序网站制作需要准备什么资料,如何制作小程序?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
建站主机选虚拟主机还是云服务器更好?
北京专业网站制作设计师招聘,北京白云观官方网站?
Swift中switch语句区间和元组模式匹配
建站之星如何助力企业快速打造五合一网站?
Python文件管理规范_工程实践说明【指导】
如何通过西部数码建站助手快速创建专业网站?
如何通过虚拟主机快速完成网站搭建?
如何选择可靠的免备案建站服务器?
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
网站微信制作软件,如何制作微信链接?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?
如何基于PHP生成高效IDC网络公司建站源码?
建站之星安装提示数据库无法连接如何解决?
网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?
,柠檬视频怎样兑换vip?
教学论文网站制作软件有哪些,写论文用什么软件
?
高端企业智能建站程序:SEO优化与响应式模板定制开发
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
已有域名能否直接搭建网站?
如何高效配置IIS服务器搭建网站?
电商平台网站制作流程,电商网站如何制作?
如何选择域名并搭建高效网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。