关于js事件的一些注意点

<!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 num1 = document.getElementById('first-number');
    var num2 = document.getElementById('second-number');

    function add() {
        document.getElementById('result').innerHTML = Number(num1.value)+Number(num2.value);
    }

    function min() {
        document.getElementById('result').innerHTML =Number (num1.value)- Number(num2.value);
    }

    function cheng() {
        document.getElementById('result').innerHTML = Number(num1.value)* Number(num2.value);
    }

    function chu() {
        document.getElementById('result').innerHTML = Number(num1.value)/ Number(num2.value);
    }

    document.getElementById("add-btn").onclick = add;
    document.getElementById("minus-btn").onclick = min;
    document.getElementById("times-btn"). onclick = cheng;
    document.getElementById("divide-btn").onclick = chu;


</script>
</body>

这是一个很简单的代码,但是我调了很久,也有一开始学业务不熟的原因。
注意点:
1、获取input框的输入这个操作是时时更新的,也就是说input框元素对应的值都是当前最新值,也就不需要每次点击时再进行一次获取操作,直接在最开始定义一个变量是input框元素,后面每个函数引用此元素的值的都是最新值。

更新:
在这里插入图片描述
一般定义的时候定义这个元素本身,而不去定义元素的value,以此为例,如果一开始直接定义

var dec_number = document.getElementById("dec-number").value

那么dec_number的值一直会是初始值,因为编译是从上到小编译,后面引用的时候没有再去查找表单内容的操作;
如果定义这个元素,后面每次点击按钮,都会调用这个函数,而函数参数是这个元素的value,这样就有了获取表单内容的操作,也就保证了每次的参数都是表单的最新值;

2、如果直接在HTML文件里面添加事件,应该是这样:

<button id="add-btn" onclick="add()"></button>
<button id="minus-btn" onclick="min()"></button>
<button id="times-btn" onclick="cheng()"></button>
<button id="divide-btn" onclick="chu()"></button>

onclick后面的函数要用括号,相当是是进行一次操作;
如果是在script标签里面添加事件,应该是这样:

document.getElementById("add-btn").onclick = add;
    document.getElementById("minus-btn").onclick = min;
    document.getElementById("times-btn"). onclick = cheng;
    document.getElementById("divide-btn").onclick = chu;

如果函数有参数,上面的方法就错了,应该要加function:
在这里插入图片描述
3、直接通过input的value值获得是字符串,要转化位number才能运算;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值