欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3?身份證校驗(yàn)、識別性別/生日/年齡的操作代碼

 更新時間:2024年07月09日 14:25:47   作者:SummerGao.  
這篇文章主要介紹了vue3?身份證校驗(yàn)、識別性別/生日/年齡的操作代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),表單項綁定 @change 事件,?定義身份驗(yàn)證規(guī)則規(guī)則,感興趣的朋友跟隨小編一起看看吧

表單項綁定 @change 事件

<template>
  <el-form ref="employeeFormRef" :model="form" :rules="rules" label-width="120px">
    <el-form-item label="身份證號" prop="idCardNo">
      <el-input v-model="form.idCardNo" placeholder="請輸入身份證號" @change="idCardNoChange" />
    </el-form-item>
    <el-form-item label="出生日期" prop="dateOfBirth">
      <el-date-picker clearable
                      v-model="form.dateOfBirth"
                      type="date"
                      value-format="YYYY-MM-DD"
                      placeholder="請選擇出生日期">
      </el-date-picker>
    </el-form-item>
    <el-form-item label="年齡" prop="age">
      <el-input v-model="form.age" placeholder="請輸入年齡" />
    </el-form-item>
    <el-form-item label="性別" prop="sex">
      <el-select v-model="form.sex" placeholder="請選擇性別">
        <el-option
          v-for="dict in sys_user_sex"
          :key="dict.value"
          :label="dict.label"
          :value="dict.value"
        ></el-option>
      </el-select>
    </el-form-item>
  </el-form>
</template>

 定義身份驗(yàn)證規(guī)則規(guī)則

const isIdCardNo = (rule, value, callback) => {
  var arrExp = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];//加權(quán)因子
  var arrValid = [1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2];//校驗(yàn)碼
  if (/^\d{17}\d|x$/i.test(value)) {
    var sum = 0, idx;
    for (var i = 0; i < value.length - 1; i++) {
      // 對前17位數(shù)字與權(quán)值乘積求和
      sum += parseInt(value.substr(i, 1), 10) * arrExp[i];
    }
    // 計算模(固定算法)
    idx = sum % 11;
    // 檢驗(yàn)第18為是否與校驗(yàn)碼相等
    if (arrValid[idx] == value.substr(17, 1).toUpperCase()) {
      callback()
    } else {
      form.value.sex = '';
      form.value.dateOfBirth = '';
      form.value.age = '';
      callback("身份證格式有誤");
    }
  } else {
    form.sex = '';
    form.dateOfBirth = '';
    form.value.age = '';
    callback("身份證格式有誤");
  }
};
const data = reactive<PageData<EmployeeForm, EmployeeQuery>>({
  rules: {
    idCardNo: [
      { required: true, message: "身份證號不能為空", trigger: "blur" },
      {	//調(diào)用定義的方法校驗(yàn)格式是否正確
        validator: isIdCardNo, trigger: "blur"
      }
    ],
  }
});

 識別性別、出生日期

// 身份證識別性別出生日期
const idCardNoChange = () => {
  const reg =
    /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/;
  if (reg.test(form.value.idCardNo)) {
    let org_birthday = form.value.idCardNo.substring(6, 14);
    let org_gender = form.value.idCardNo.substring(16, 17);
    let sex = org_gender % 2 == 1 ? "0" : "1";
    let birthday =
      org_birthday.substring(0, 4) +
      "-" +
      org_birthday.substring(4, 6) +
      "-" +
      org_birthday.substring(6, 8);
    form.value.sex = sex;
    form.value.dateOfBirth = birthday;
    form.value.age = ageValue(birthday).age;
  } else {
    return false;
  }
};

出生日期計算年齡

/**
 * 獲取年齡
 * @param val
 * @returns {{month: unknown, day: unknown, age: unknown}}
 */
const ageValue= (val?: String) => {
  // 新建日期對象
  let date = new Date()
  // 今天日期,數(shù)組,同 birthday
  let birthdayDate = new Date(val)
  let birthday = [birthdayDate.getFullYear(), birthdayDate.getMonth(), birthdayDate.getDate()]
  let today = [date.getFullYear(), date.getMonth() + 1, date.getDate()]
  // 分別計算年月日差值
  let age = today.map((value, index) => {
    return value - birthday[index]
  })
  // 當(dāng)天數(shù)為負(fù)數(shù)時,月減 1,天數(shù)加上月總天數(shù)
  if (age[2] < 0) {
    // 簡單獲取上個月總天數(shù)的方法,不會錯
    let lastMonth = new Date(today[0], today[1], 0)
    age[1]--
    age[2] += lastMonth.getDate()
  }
  // 當(dāng)月數(shù)為負(fù)數(shù)時,年減 1,月數(shù)加上 12
  if (age[1] < 0) {
    age[0]--
    age[1] += 12
  }
  return {age:age[0],month:age[1],day:age[2]}
}

到此這篇關(guān)于vue3 身份證校驗(yàn)、識別性別/生日/年齡的文章就介紹到這了,更多相關(guān)vue3 身份證校驗(yàn)、識別性別/生日/年齡內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談Vue2.4.0 $attrs與inheritAttrs的具體使用

    淺談Vue2.4.0 $attrs與inheritAttrs的具體使用

    這篇文章主要介紹了淺談Vue2.4.0 $attrs與inheritAttrs的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • 微信小程序開發(fā)實(shí)現(xiàn)消息框彈出

    微信小程序開發(fā)實(shí)現(xiàn)消息框彈出

    在小程序的wxml文件中創(chuàng)建消息框,消息框一般包含要提示的消息內(nèi)容以及確認(rèn)和取消按鈕,在小程序的wxss文件中定義消息框的樣式,在小程序的js文件中,我們需要通過Animation對象實(shí)現(xiàn)消息框的彈出動畫
    2023-12-12
  • 前端大文件上傳與下載(分片上傳)的詳細(xì)過程

    前端大文件上傳與下載(分片上傳)的詳細(xì)過程

    最近遇見一個需要上傳超大大文件的需求,所以下面這篇文章主要給大家介紹了關(guān)于前端大文件上傳與下載(分片上傳)的詳細(xì)過程,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • vue靜態(tài)界面之左二級菜單右表單表格的實(shí)例代碼

    vue靜態(tài)界面之左二級菜單右表單表格的實(shí)例代碼

    這篇文章主要介紹了vue靜態(tài)界面之左二級菜單右表單表格,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • vue項目中實(shí)現(xiàn)el-dialog組件可拖拽效果

    vue項目中實(shí)現(xiàn)el-dialog組件可拖拽效果

    本文主要介紹了vue項目中實(shí)現(xiàn)el-dialog組件可拖拽效果,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 詳解vue服務(wù)端渲染(SSR)初探

    詳解vue服務(wù)端渲染(SSR)初探

    本篇文章主要介紹了詳解vue服務(wù)端渲染(SSR)初探,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • el-table?動態(tài)合并不定項多級表頭的方法

    el-table?動態(tài)合并不定項多級表頭的方法

    本文主要介紹了el-table?動態(tài)合并不定項多級表頭的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Vuex中Store的簡單實(shí)現(xiàn)

    Vuex中Store的簡單實(shí)現(xiàn)

    這篇文章主要介紹了Vuex中Store的簡單實(shí)現(xiàn),為了在 Vue 組件中訪問 this.$store property,你需要為 Vue 實(shí)例提供創(chuàng)建好的 store,Vuex 提供了一個從根組件向所有子組件,以 store 選項的方式 注入 該 store 的機(jī)制,需要的朋友可以參考下
    2023-11-11
  • Vue3使用Element?Plus實(shí)現(xiàn)列表界面的方法步驟

    Vue3使用Element?Plus實(shí)現(xiàn)列表界面的方法步驟

    寫后臺管理的時候會有很多列表以及相應(yīng)的條件查詢,下面這篇文章主要給大家介紹了關(guān)于Vue3使用Element?Plus實(shí)現(xiàn)列表界面的方法步驟,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • vue自定義樹狀結(jié)構(gòu)圖的實(shí)現(xiàn)方法

    vue自定義樹狀結(jié)構(gòu)圖的實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于vue自定義樹狀結(jié)構(gòu)圖的實(shí)現(xiàn)方法,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10

最新評論