利用JavaScript实现加减乘除及遇到的相关问题

作为一个刚开始学JavaScript的小菜鸟,希望和大家分享一下在学习中遇到的问题,这算是我写的第一个js小程序吧,虽然很小很简单,但是在实现的过程中遇到了很多问题。

问题一:

if(document.getElementId(first-name).onclick)

当我试图用连续几个if.....else if语句来判断button是否被点击时,出现错误。原因在于事件处理函数的onclick的返回值并不是简单的true或者false。这也反映出我写代码的过程中逻辑十分不严谨。解决方法见链接:点击打开链接

问题二:

document.getElementId(first-name).value获取的是字符串,如果想进行加法,需要使用parseInt()等函数转换成数值型,进行减法、乘法、除法则不必。

问题三:

一个很菜鸟但是我研究了半天的问题......一开始我给a、b直接赋值了document.getElementId("").value,然后发现一直赋值不成功,a、b一直等于0。终于我找到了一个思否的问题:点击打开链接。也就是说我没有理解:JavaScript脚本在浏览器上是加载完成后立即运行的。(我这理解能力),其他具体内容如果有人看我博文的话就移步链接吧~我只是只小菜鸟搬运工~


最后上我写的不怎么规范好看的代码:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">    
    <title>IFE ECMAScript</title>
</head>
<body>        
    <input id="first-number" type="number" value="0" placeholder="第一个数字">
    <input id="second-number" type="number" value="0" placeholder="第二个数字">
    <button id="add-btn">加</button>
    <button id="minus-btn">减</button>
    <button id="times-btn">乘</button>
    <button id="divide-btn">除</button>
    <p id="result">运算结果</p>
    <script>
            var a = document.getElementById("first-number");
            var b = document.getElementById("second-number");
            var btn1 = document.getElementById("add-btn");
            var btn2 = document.getElementById("minus-btn");
            var btn3 = document.getElementById("times-btn");
            var btn4 = document.getElementById("divide-btn");
            btn1.onclick = function(){
                document.getElementById("result").innerHTML = parseInt(a.value) + parseInt(b.value);
            }
            btn2.onclick = function(){
                document.getElementById("result").innerHTML = a.value - b.value;
            }
            btn3.onclick = function(){
                document.getElementById("result").innerHTML = a.value * b.value;
            }
            btn4.onclick = function(){
                document.getElementById("result").innerHTML = a.value / b.value;
            }
    </script>
</body>
</html>


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值