我有这个html输入:
Rows: <input type="text" class="rows" onkeypress="return isNumber(event)"><br>
和这个javascript函数只验证数字
function isNumber(evt) {
evt = (evt) ? evt : window.event;
var charCode = (evt.which) ? evt.which : evt.keyCode;
if (charCode > 31 && (charCode < 48 || charCode > 57)) {
return false;
}
return true;
}
但我想使用微分支来做这样的事情:
function isNumber(evt){
evt = evt || window.event;
var charCode = evt.which || evt.keyCode;
(charCode > 31 && (charCode < 48 || charCode > 57)) && return false;
return true;
}
事情是最后两行没有用。
答案 0 :(得分:3)
return
是一个语句而不是表达式,因此不能用作逻辑运算符的参数。
但是,在您的情况下,最后两行可以重写为单个return
语句,只需将条件反转为if
子句:
return !(charCode > 31 && (charCode < 48 || charCode > 57));
或者,作为zerkms notes,您可以通过翻转运算符(!
&lt; =&gt; &&
和||
&lt; =来丢失<
&gt; >=
),在我看来,这提高了可读性:
return charCode <= 31 || (charCode >= 48 && charCode <= 57);
答案 1 :(得分:1)
根据您的描述,看起来您正在寻找条件检查并返回:
function isNumber(evt){
evt = evt || window.event;
var charCode = evt.which || evt.keyCode;
return !(charCode > 31 && (charCode < 48 || charCode > 57));
}