Luhn校验
实现Luhn算法,用于验证各种身份证号码,如信用卡号、IMEI号码、国家提供者标识符号码等。
- 使用
String.prototype.split()
、Array.prototype.reverse()
和Array.prototype.map()
结合parseInt()
来获取数字数组。 - 使用
Array.prototype.shift()
获取最后一位数字。 - 使用
Array.prototype.reduce()
来实现Luhn算法。 - 如果
sum
可以被10
整除,则返回true
,否则返回false
。
const luhnCheck = num => {
const arr = (num + '')
.split('')
.reverse()
.map(x => parseInt(x));
const lastDigit = arr.shift();
let sum = arr.reduce(
(acc, val, i) => (i % 2 !== 0 ? acc + val : acc + ((val *= 2) > 9 ? val - 9 : val)),
0
);
sum += lastDigit;
return sum % 10 === 0;
};
luhnCheck('4485275742308327'); // true
luhnCheck(6011329933655299); // true
luhnCheck(123456789); // false