gpt4 book ai didi

javascript - 我如何使用 html 和 javascript 制作一种计算器?

转载 作者:行者123 更新时间:2023-11-30 11:32:37 25 4
gpt4 key购买 nike

我是一名初级程序员,我想完成这项工作,但没有成功。你能帮我解释一下哪里出了问题吗?例如,如果我输入 20 以下,我希望它告诉我步行到我选择的任何星球需要多长时间。其中大部分是弄清楚如何让代码存储用户选择的任何选项,然后将其应用于年龄并使用数据来计算它。谢谢!

<legend>basic info</legend>
<p> What is your destination?
<select onchange = "selectDestination(this.value)">
<option value="mercury">Mercury</option>
<option value="venus">Venus</option>
<option value="mars">Mars</option>
<option value="jupiter">Jupiter</option>
<option value="saturn">Saturn</option>
<option value="uranus">Uranus</option>
<option value="neptune">Neptune</option>
<option value="pluto">Pluto</option>
</select>
<script type="text/javascript">
var planets = new Array();
planets['mercury'] = 48000000;
planets['venus']=25000000
planets['mars']=25000000
planets['jupiter']=33900000
planets['saturn']=365000000
planets['uranus']=1200000000
planets['neptune']=2600000000
planets['pluto']=2800000000

function selectDestination(selectedValue) {
window.alert(selectedValue + " distance=" + planets[selectedValue]);
}
</script>
</p>
<p>
<label>how old are you?</label>
<form id="form" onsubmit="return false;">
<input type="number" id="userInput">
<input type="submit" onclick="age()">
</form>
<script type="text/javascript">
function age()
{
var input = document.getElementById("userInput");
alert(input);
}
if(age<20);
{
alert("YOU ARE UNDER 20");
var runSpeed=6.3;
var walkSpeed=2.1
var water = 1.5;
var calories = 2500;
var runTime = planets[selectedValue]/runSpeed;
var runDays = runTime/24
document.write("it will take "+runTime+" hours and "+runDays+" days to make it to"+selectedValue);
}
if(21<age>45) {
alert("YOU ARE AT YOUR PHYSICAL PEAK");
var runSpeed=8.3;
var walkSpeed=3.1;
var water = 2;
var calories = 3000;
var runTime = planets[selectedValue]/runSpeed;
var runDays = runTime/24;
document.write("it will take "+runTime"hours and"+runDays+"days to make it to"+selectedValue);
}
if(age<45){
alert("YOU ARE PROBABLY TOO OLD TO TAKE THIS TRIP");
var runSpeed=5.3;
var walkSpeed=1.1;
var water=1.5;
var calories=3000;
var runTime = planets[selectedValue]/runSpeed;
var rundays = planets[selectedValue]/24;
document.write("it will take "+runTime"hours and"+runDays+"days to make it to"+selectedValue);
}
</script>
</p>

最佳答案

这里的代码不起作用。

      var planets = new Array();
planets['mercury'] = 48000000;
planets['venus']=25000000
planets['mars']=25000000
planets['jupiter']=33900000
planets['saturn']=365000000
planets['uranus']=1200000000
planets['neptune']=2600000000
planets['pluto']=2800000000

你声明的是一个数组,而你想要压入其中的是对象。

理想情况下,您希望行星看起来像 var planets = [ {planet: 'mercury', distance: 48000000}, {planet: 'venus', distance: 25000000 }, ... ]

现在,没有任何事情发生,因为您的语法正在寻找一个键为 mercuryvenus 的对象,但没有找到任何东西。

接下来您应该做的是能够 console.log() 无论用户输入什么年龄。确保您的函数 age() 接受一个参数,因此它可能看起来更像 age(val)

一旦您 console.log() 记录了用户输入的年龄,您应该非常接近。之后您所要做的就是获取用户选择的行星,您可以通过遍历 planets 数组并将用户选择的内容与数组中的内容进行匹配来完成此操作。像 planets.filter(planet => planet.indexOf(planetUserSelected) !== -1) 这样的东西会返回你正在寻找的对象,你可以 console.log( ) 该值并从那里开始。

关于javascript - 我如何使用 html 和 javascript 制作一种计算器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45666974/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com