JS

在线预览

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <style>
    #msg{
      color: red;
    }
  </style>
</head>
<body>
  身份证号:<input id="id-card" type="text">(前17位)<br>
  (校验位)最后一位为:<span id="msg"></span><span id="check-digit"></span><br>
  <button onclick="calculate()">计算</button><br>
  <script>
    "use strict";
    // 前17位每项的系数
    let coefficient = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];
    // 除11取余的结果对应的校验位(最后一位)的值
    let checkDigitMap = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'];
    function calculate(){
      var idCard = document.querySelector("#id-card");
      var checkDigit = document.querySelector("#check-digit");
      var msg = document.querySelector("#msg");
      var sum = 0;
      checkDigit.innerHTML = msg.innerHTML = "";
      if(idCard.value.length < 17){
        msg.innerHTML = "至少输入身份证前17位";
        return
      }
      for (var i = 0; i < 17; i++) {
        sum += idCard.value[i] * coefficient[i];
      }
      checkDigit.innerHTML = checkDigitMap[sum % 11];
    }
  </script>
</body>
</html>
原文地址:https://www.cnblogs.com/jffun-blog/p/11255051.html