JavaScript onclick 事件处理程序无法正常运行

标签 javascript onclick event-handling dom-events

由于某种原因,我的 onclick JavaScript 事件处理程序无法正常运行。

这是我的标记、脚本和样式:

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Quadratic Root Finder</title>

<script>
document.ready = function() {
    document.getElementById('calculate').onClick.calculateQuad()
    {
        var inputa = document.getElementById('variablea').value;
        var inputb = document.getElementById('variableb').value;
        var inputc = document.getElementById('variablec').value;
        
        root = Math.pow(inputb,2) - 4 * inputa * inputc;
        root1 = (-inputb + Math.sqrt(root))/2*inputa
        root2 = (-inputb + Math.sqrt(root))/2*inputa 
        
        document.getElementById('root1').value = root1;
        document.getElementById('root2').value = root2;
        if(root<'0')
        {
            alert('This equation has no real solution.')
        }
        else {
            if(root=='0')
            {
                document.getElementById('root1').value = root1
                document.getElementById('root2').value = 'No Second Answer'
            }
            else {
                document.getElementById('root1').value = root1
                document.getElementById('root2').value = root1
                }
            }
    };
    document.getElementById('erase').onClick.document.getElementById('form1').reset();
}
</script>

<style>
#container
{
    text-align: center;
}
</style>

</head>

<body>
<div id="container">
<h1>Quadratic Root Finder!</h1>
<form id="form1">
    a:<input id="variablea" value="" type="text">
    <br/>
    b:<input id="variableb" value="" type="text">
    <br />
    c:<input id="variablec" value="" type="text">
    <br />
    <input id="calculate" value="Calculate!" type="button">
    <input id="erase" value="Clear" type="button">
    <br />
    <br />
    Roots:
    <br />
    <input id="root1" type="text" readonly>
    <br />
    <input id="root2" type="text" readonly>
</form>
</div>
</body>
</html>

有可以解释的原因吗?

最佳答案

这是错误的
document.getElementById('calculate').onClick.calculateQuad()
一定是
document.getElementById('计算').onClick = function ()

这也是错误的
document.getElementById('erase').onClick.document.getElementById('form1').reset();
修复:
document.getElementById('erase').onClick = function(){document.getElementById('form1').reset();}

关于JavaScript onclick 事件处理程序无法正常运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3911415/

相关文章:

javascript - 是否可以从脚本中检索 Javascript 变量以在 R 中使用它

javascript - 通过 javascript 使用自定义 header 检查凭据后加载 html 页面

Javascript 显示/隐藏 div 并根据可见的 div 更改 css 类?

javascript - 简单的 javascript onClick 用于表数据

java - 检测对表单控件中文本的所有更改(由用户进行)

events - 在子组件中监听父组件的事件并在无集线器的vue中执行子组件的方法

javascript - 在 ONCLICK 事件上调用函数

javascript - 使用/jQuery 组织 Javascript

java - 使用 XML onClick 时出现 Android Dialog NoSuchMethodException 错误

powershell - PowerShell,当 “Wait-Event”触发时从 “Register-ObjectEvent -Action”返回吗?