Javascript最大值和最小值不起作用



我正在尝试创建一个页面,让用户输入三个数字,并在下面根据输入打印最大值和最小值。我使用了Math.max/min函数,还尝试了if语句,但当我单击submit时,什么都不会显示。如有真知灼见,不胜感激!

function max() {
    var x = document.getElementById("num1").value;
    var y = document.getElementById("num2").value;
    var z = document.getElementById("num3").value;
    var maximum = Math.max(parseInt(x), parseInt(y), parseInt(z));
    document.getElementById("max").innerHTML= maximum;
    }
    function min() {
    var x = parseInt(document.getElementById("num1").value);
    var y = parseInt(document.getElementById("num2").value);
    var z = parseInt(document.getElementById("num3").value);

    document.getElementById("min").innerHTML = Math.min(x,y,z);
    }

这是我的html

<p>Enter First Number:</p>
<input type="text" name = "number1" id="num1"><br>
<p>Enter Second Number</p>
<input type="text" name = "number2" id="num2"><br>
<p>Enter third number</p>
<input type="text" name = "number3" id="num3"><br>
<input type="submit" value="Submit" onclick="max(); min(); "><br /> 
<p>Max =</p><p id ="max"></p><br />
<p>Min =</p><p id ="min"></p><br />

<input type="submit"/>替换为<button type="submit" value="" onclick="minmax();">Submit</button>

并添加JS函数:

function minmax() {
    min();
    max();
}

您的问题似乎与如何附加事件有关。

当我使用时,它工作正常

document.querySelector( '[type="submit"]' ).addEventListener( 'click', function() {
   max();
   min();
}, false );

http://jsfiddle.net/yemxrmqq/

您只需要更改与按钮相关的标签,而不是:

<input type="submit" value="Submit" onclick="max(); min(); "><br />

刚放:

<button type="submit" value="Submit" onclick="max(); min()">Click</button><br />

这里没有任何答案告诉您代码不起作用的原因。

内联侦听器中的标识符首先被解析为放置它们的元素的属性。输入元素具有默认的max属性,因此在内联侦听器中,标识符max将引用输入的max

<input onclick="console.log(max)">

显示''(即空字符串)。

因此,您可以将函数的名称更改为更有意义的名称,也可以更改调用它们的上下文,这样就不会在元素上解析标识符,OP代码就可以工作了。例如

<input type="submit" value="Submit" onclick="callBoth()">

function callBoth() {
  max();
  min();
}

顺便说一句,表单外的输入类型submit只是一个按钮,所以您应该使用:

<input type="button" ...>

最新更新