Điều đó phụ thuộc, bạn cũng muốn truyền chuỗi như các số nguyên tiềm năng không?
Điều này sẽ làm:
function isInt(value) {
return !isNaN(value) &&
parseInt(Number(value)) == value &&
!isNaN(parseInt(value, 10));
}
Với các hoạt động của Bitwise
Phân tích và kiểm tra đơn giản
function isInt(value) {
var x = parseFloat(value);
return !isNaN(value) && (x | 0) === x;
}
Đoản mạch và lưu thao tác phân tích cú pháp:
function isInt(value) {
if (isNaN(value)) {
return false;
}
var x = parseFloat(value);
return (x | 0) === x;
}
Hoặc có lẽ cả hai trong một lần bắn:
function isInt(value) {
return !isNaN(value) && (function(x) { return (x | 0) === x; })(parseFloat(value))
}
Các xét nghiệm:
isInt(42) // true
isInt("42") // true
isInt(4e2) // true
isInt("4e2") // true
isInt(" 1 ") // true
isInt("") // false
isInt(" ") // false
isInt(42.1) // false
isInt("1a") // false
isInt("4e2a") // false
isInt(null) // false
isInt(undefined) // false
isInt(NaN) // false
Đây là câu đố: http://jsfiddle.net/opfyrqwp/28/
Hiệu suất
Thử nghiệm cho thấy giải pháp ngắn mạch có hiệu suất tốt nhất (ops / giây).
// Short-circuiting, and saving a parse operation
function isInt(value) {
var x;
if (isNaN(value)) {
return false;
}
x = parseFloat(value);
return (x | 0) === x;
}
Đây là một điểm chuẩn:
http://jsben.ch/#/htLVw
Nếu bạn thích một hình thức ngắn mạch, khó hiểu của ngắn mạch:
function isInt(value) {
var x;
return isNaN(value) ? !1 : (x = parseFloat(value), (0 | x) === x);
}
Tất nhiên, tôi khuyên bạn nên để công cụ khai thác xử lý việc đó.
parseInt.