vue3?身份證校驗、識別性別/生日/年齡的操作代碼
更新時間:2024年07月09日 14:25:47 作者:SummerGao.
這篇文章主要介紹了vue3?身份證校驗、識別性別/生日/年齡的操作代碼,本文通過實例代碼給大家介紹的非常詳細,表單項綁定 @change 事件,?定義身份驗證規(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>定義身份驗證規(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];//校驗碼
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;
// 檢驗第18為是否與校驗碼相等
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)用定義的方法校驗格式是否正確
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]
})
// 當天數(shù)為負數(shù)時,月減 1,天數(shù)加上月總天數(shù)
if (age[2] < 0) {
// 簡單獲取上個月總天數(shù)的方法,不會錯
let lastMonth = new Date(today[0], today[1], 0)
age[1]--
age[2] += lastMonth.getDate()
}
// 當月數(shù)為負數(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 身份證校驗、識別性別/生日/年齡的文章就介紹到這了,更多相關(guān)vue3 身份證校驗、識別性別/生日/年齡內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談Vue2.4.0 $attrs與inheritAttrs的具體使用
這篇文章主要介紹了淺談Vue2.4.0 $attrs與inheritAttrs的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-03-03
vue項目中實現(xiàn)el-dialog組件可拖拽效果
本文主要介紹了vue項目中實現(xiàn)el-dialog組件可拖拽效果,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01
Vue3使用Element?Plus實現(xiàn)列表界面的方法步驟
寫后臺管理的時候會有很多列表以及相應的條件查詢,下面這篇文章主要給大家介紹了關(guān)于Vue3使用Element?Plus實現(xiàn)列表界面的方法步驟,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-04-04
vue自定義樹狀結(jié)構(gòu)圖的實現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于vue自定義樹狀結(jié)構(gòu)圖的實現(xiàn)方法,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10

