이 기사의 예에서는 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>
이 기사가 모든 사람의 JavaScript 프로그래밍 설계에 도움이 되기를 바랍니다.