id属性是具有唯一性的,也就是说同一个网页不允许有多个元素具有相同的id(id的意思就是身份证,你觉得身份证号码有可能重号吗?),否则的话只有第一个元素的id才有效。如果你想让多个元素具有相同的名字,可以使用name属性(现实生活中姓名相同是允许的)。
另外你的算法本身有问题,比方说你在值1先输入1,触发KeyUp事件,总值-1,然后在值1再输入0,会再次触发KeyUp事件,总值再-10,也就是说实际减了11,而不是你希望的10!下面是一种解决办法(也许不是最佳的):
<!DOCTYPE html><html>
<head>
<script type="text/javascript">
window.onload=function(){
var left=document.getElementById("left")
var lv=0
left.oninput=function(){
if(!isNaN(this.value))lv=Number(this.value)
}
var rights=document.getElementsByName("right")
for(var i=0i<rights.lengthi++){
rights[i].oninput=function(){
for(var j=0,s=0j<rights.lengthj++){
if(!isNaN(rights[j].value))s+=Number(rights[j].value)
}
left.value=lv-s
}
}
}
</script>
</head>
<body>
<span id="message" style="color:red"></span>
<br> 总值: <input type="text" id="left"/>
<br>
<br> 值1: <input type="text" name="right"/>
<br> 值2: <input type="text" name="right"/>
<br> 值3: <input type="text" name="right"/>
<br> 值4: <input type="text" name="right"/>
<br> 值5: <input type="text" name="right"/>
<br>
</body>
</html>
这个代码还解决了当你在值1、值2...中取消输入时,总值自动恢复原值的问题。
补充说明:测试文本框输入的是否为合法数字时,不需要用正则去测试,只需用js原生的函数isNaN()即可
可以直接相减,获得的结果就是两个时间之间相差的毫秒数,然后可以再从中计算获得相差的年月日时分秒来。
比如下面的代码是获得今年(2018年)剩余的天数:
var d1=new Date()var d2=new Date(2019,0,1)
var d=parseInt((d2-d1)/1000/3600/24)
console.log("2018年剩余的天数为"+d+"天")
你这个不叫减,你这个在js中是截取,用substring实现。你如果能给出“abcd”-"efg"=???的答案,那么你就可以根据你的理论重载一下运算符,然后让-号具有你所期待的功能! 如果每次都去掉最后一个字符,就用substring就行了,比如:var str = "1234"var result = str.substring(0,str.length-2) //result = "123"