JavaScript 函数 不使用输入标签的 onchange 属性

JavaScript function Not Working with onchange attribute of input tag

本文关键字:标签 onchange 属性 输入 函数 JavaScript      更新时间:2023-09-26

我一直在尝试从HEAD FIRST JAVASCRIPT复制邓肯甜甜圈示例,但是函数subTotal()永远不会由onchange事件触发,当我查看HTML参考时,我没有在提供的列表中找到任何onchange事件。

邓肯.html

    <html>
    <head><title>Duncan Online Donut's Service</title></head>
    <script type="text/javascript">
        function subTotal(){
            document.write("working");
            const TAXRATE = 0.095;
            const DONUTRATE = 0.5;
            var tax = 0;
            var subTotal = 0;
            var total = 0;
            var cakedonut = parseInt(document.getElementById("cakedonut").value);
            var glazedonut = parseInt(document.getElementById("glazedonut").value);
            if(isNaN(cakedonut))
                cakedonut = 0;
            if(isNaN(glazedonut))
                glazedounut = 0;
            subTotal = (cakedonut + glazedonut)* DONUTRATE ;
            tax = subTotal * TAXRATE ;
            total = subTotal + tax ;
            document.getElementById("subTotal").value = "$" + subTotal.toFixed(2);
            document.getElementById("tax").value = "$" + tax.toFixed(2);
            document.getElementById("total").value = "$" + total.toFixed(2);    
        }
    </script>
    <body>
        <h1><b><i>Duncan Online Donut's Service</i></b></h1>
        <form>
            Name : <input id="name" type="text" name="name"/><br><br>
            #no of cake donuts : <input id="cakedonut" type="text" name="cakedonut" onchange="subTotal()"/><br><br>
            #no of glazed donuts : <input id="glazedonut" type="text" name="glazedonut" onchange="subTotal("/><br><br>
            subTotal : <input id="subTotal" type="text" name="subTotal" /><br><br>
            tax : <input id="tax" type="text" name="tax" /><br><br>
            Total : <input id="total" type="text" name="total"/><br><br>
            <input type="submit"/><br><br>
        </form>
    </body>
</html>

JSFiddle

以上是我的代码。我尝试在IE and Chrome上运行它,但徒劳无功。提前谢谢。

问题是你已经定义了一个变量和一个同名的函数subTotal并且变量声明覆盖了函数定义。将函数名称更改为任何表示subTotal1它将起作用的名称。

捷信链接

更改函数名称。 不要使用subTotal();,也不要使用document.write("working");

function subTotalnew()
{
alert('working');
}

onchange="subTotalnew()输入后blur工作.

oninput="subTotalnew()输入时它会工作entering something.