JavaScript编程精解 模拟抛物运动的代码实现
沉沙 2018-06-04 来源 : 阅读 1515 评论 0

摘要:抛物运动是由重力感应引起的一种运动,本文将用简单的JavaScript代码来模拟抛物运动的实现,希望阅读本篇文章以后大家有所收获,帮助大家对JavaScript的理解更加深入。

抛物运动是由重力感应引起的一种运动,这篇文章将用简单的JavaScript代码来模拟抛物运动的实现,下面的代码对我们学习JavaScript非常有帮助。

这段JavaScript代码模拟重力状态下的抛物运动,可设置以下参数:横向初速度、纵向初速度、重力加速度(如果这个加速度是一个随时间变化的值,就能达到其他非匀加速运动的效果了)、动画间隔时间等,相对专业,下面是代码:

<!doctype html><html><head><title>js抛物运动</title><meta charset="utf-8" /><style type="text/css">
*{padding:0;margin:0;}body{font-size:13px;padding:10px;}p{margin:2px;}.wrap{position:relative;width:1000px;height:550px;margin:0 auto;border:1px solid #ccc;margin-top:50px;}#fall{width:20px;font-size:1px;height:20px;background:#000;position:absolute;top:0;left:0;}</style></head><body><h3>模拟重力状态下的抛物运动(假使1px==1mm)</h3><p>横向初速度:<input id="Vx" type="text" value="2" />px/ms</p><p>纵向初速度:<input id="Vy" type="text" value="-2" />px/ms</p><p>重力加速度:<input id="a" type="text" value="0.0098" />px/平方ms</p><p>(如果这个加速度是一个随时间变化的值,就能达到其他非匀加速运动的效果了。)</p><p>单位时间:<input id="t" type="text" value="10" />(记录运动的时间间隔)<p><input type="button" value="演示" onclick="demo(document.getElementById('Vx').value, document.getElementById('Vy').value, document.getElementById('a').value, document.getElementById('t').value)"/></p><div class="wrap"><div id="fall">o</div></div></body><script type="text/javascript">function demo(x,y,a,t) {var f=document.getElementById('fall');var Vx=parseInt(x),
Vy=parseInt(y),
g=a,
t=parseInt(t),
h=0,l=0,Sx=0,Sy=0;var i=setInterval(function(){if(f){
Sx+=Vx*t;
l=Sx;
Vy+=g*t;
h+=Vy*t;
f.style.left=l+'px';
f.style.top=h+'px';if(h>500||l>900)clearInterval(i);
}
},t);
}</script></html>


本文由职坐标整理发布,更多相关内容,请关注职坐标WEB前端JavaScript频道!


本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved