You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

291 lines
8.6 KiB

<template>
<div class="content">
<el-header>
<h3 class="title">河北省计量业务应用平台</h3>
</el-header>
<div class="user-from">
<el-form :model="userForm" :rules="rules" ref="userForm" label-width="120px" class="demo-userForm">
<el-form-item label="身份证号" prop="idNo">
<el-input v-model="userForm.idNo" @blur="onInputBlur" placeholder="请输入身份证号" :maxlength="18"></el-input>
</el-form-item>
<el-form-item label="真实姓名" prop="name">
<el-input v-model="userForm.name" placeholder="请输入真实姓名"></el-input>
</el-form-item>
<el-form-item label="个人手机号" prop="mobile">
<el-input v-model="userForm.mobile" placeholder="请输入手机号" ></el-input>
<el-button class="Tips" type="text" :disabled='isDisabled' @click.stop.prevent="getcode()">点击获取验证码 {{downTime ? downTime+'s':''}}</el-button>
</el-form-item>
<el-form-item label="手机验证码" prop="verificationCode">
<el-input v-model="userForm.verificationCode" placeholder="请输入验证码"></el-input>
</el-form-item>
<el-form-item label="用户名">
<el-input v-model="userForm.userName" :disabled="true"></el-input>
</el-form-item>
<el-form-item label="密码" prop="password">
<paddwordinput v-model="userForm.password" placeholder="请输入密码" :pastips='true' :maxlength="10"></paddwordinput>
<el-button class="Tips" type="text">密码必须为8至10位大小写字母和数字组合</el-button>
</el-form-item>
<el-form-item label="确认密码" prop="rePassword">
<paddwordinput v-model="userForm.rePassword" placeholder="请再次输入密码" :maxlength="10"></paddwordinput>
</el-form-item>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="身份证正面照" prop="idFrontPhoto">
<UploadImg @imgUrl="FrontPhotoUrl"></UploadImg>
<el-input v-model="userForm.idFrontPhoto" v-show="false"></el-input>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="身份证背面照" prop="idBackPhoto">
<UploadImg @imgUrl="BackPhotoUrl"></UploadImg>
<el-input v-model="userForm.idBackPhoto" v-show="false"></el-input>
</el-form-item>
</el-col>
</el-row>
<el-form-item style="text-align: center;">
<el-button type="primary" @click="submitForm('userForm')" :disabled="btnDisabled">注册</el-button>
<el-button @click="resetForm('userForm')">关闭</el-button>
</el-form-item>
</el-form>
</div>
</div>
</template>
<script>
import {
registUser,
getVerificationCode
} from '@/api/user1.js'
import qs from 'qs'
import UploadImg from '@/components/uploadFile/index.vue'
import paddwordinput from '@/components/passwordSafe/index.vue'
export default {
components:{ UploadImg, paddwordinput },
data() {
var validatorPhone = function (rule, value, callback) {
if (value === '') {
callback(new Error('手机号不能为空'))
} else if (!/^1\d{10}$/.test(value)) {
callback(new Error('手机号格式错误'))
} else {
callback()
}
}
var validatePass2 = (rule, value, callback) => {
if (value === '') {
callback(new Error('请再次输入密码'))
// password 是表单上绑定的字段
} else if (value !== this.userForm.password) {
callback(new Error('两次输入密码不一致!'))
} else {
callback()
}
}
return {
downTime: '',
isDisabled: false,
userForm: {
name: '',
userName: '', //用户名
password: '',
rePassword: '',
mobile: '', // 手机号
verificationCode: '',
idNo: '',
idBackPhoto: '', // 反面
idFrontPhoto: ''
},
btnDisabled: false,
rule: [{required: true, message: '不能为空', trigger: 'blur'}],
rules: {
idNo: [
{ required: true, message: '请输入身份证号', trigger: 'blur' },
{ pattern: /(^[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]$)|(^[1-9]\d{5}\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{2}$)/,
message: '身份证号格式错误', trigger: 'blur' ,
}
],
name: [
{ required: true, message: '请输入真实姓名', trigger: 'blur' }
],
mobile: [
{ required: true, validator: validatorPhone, trigger: 'blur' }
],
verificationCode: [
{ required: true, message: '请输入手机验证码', trigger: 'blur' }
],
userName: [
{ required: true, message: '请输入身份证号', trigger: 'blur' }
],
password: [
{ required: true, message: '请输入密码', trigger: 'blur' },
{ min: 8, max: 10, message: '长度在 8 到 10 个字符大小写字母和数字组合', trigger: 'blur' }
],
rePassword: [
{ required: true, validator: validatePass2, trigger: 'blur' }
],
idFrontPhoto: [
{ required: true, message: '请上传身份证正面', trigger: 'blur' }
],
idBackPhoto: [
{ required: true, message: '请上传身份证背面', trigger: 'blur' }
],
}
};
},
methods: {
// 手机验证码
getcode() {
let _this = this
if (!/^1\d{10}$/.test(_this.userForm.mobile)) {
this.$message({
type: 'error',
message: '手机号格式错误!'
});
}else {
_this.downTime = 60
let timeInterval = null
_this.isDisabled = true
timeInterval = setInterval(()=>{
--_this.downTime
if(_this.downTime == 0){
clearInterval(timeInterval)
_this.downTime = '';
_this.isDisabled = false
}
},1000)
getVerificationCode({
mobile: _this.userForm.mobile
}).then(res =>{
// this.isDisabled = false
})
}
},
FrontPhotoUrl(url){
this.userForm.idFrontPhoto = url.filePath
},
BackPhotoUrl(url){
this.userForm.idBackPhoto = url.filePath
},
submitForm(formName) {
this.btnDisabled = true
this.$refs[formName].validate((valid) => {
if (valid) {
registUser(qs.stringify(this.userForm)).then((res) => {
this.btnDisabled = false
this.$confirm('注册成功, 是否关闭页面?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'success'
}).then(() => {
window.close();
})
}).catch(() => {
this.btnDisabled = false
})
} else {
console.log('error submit!!');
this.btnDisabled = false
return false;
}
});
},
resetForm(formName) {
window.close();
this.$refs[formName].resetFields();
},
onInputBlur() { // 用户名密码
this.userForm.userName = this.userForm.idNo
},
}
}
</script>
<style lang="scss" scoped>
@import "~@/styles/variables.scss";
.el-header{
width: 100%;
background-color: #0294d7;
color: #fff;
line-height: 60px;
overflow: hidden;
position: fixed;
z-index: 99;
top: 0;
.title{
float: left;
font-size: 26px;
margin-left: 35px;
}
}
.content{
padding: 50px 0;
background-color: #f7f9fc;
}
</style>
<style lang="scss">
@import "~@/styles/variables.scss";
.user-from {
width: 860px;
padding-top: 20px;
margin: 0 auto;
.el-input__inner:focus {
border: 1px solid $border-color;
}
.Tips {
padding-left: 10px;
position: absolute;
left: 100%;
top: 0;
}
.pasTips {
display: flex;
justify-content: center;
span {
display: inline-block;
margin: 15px 10px 0 10px;
padding: 0 30px;
line-height: 30px;
border-top: 3px solid red;
opacity: 0.3;
}
span:nth-child(2) {
border-color: blue;
}
span:nth-child(3) {
border-color: green;
}
}
.avatar-uploader .el-upload {
border: 1px dashed #d9d9d9;
border-radius: 6px;
cursor: pointer;
position: relative;
overflow: hidden;
}
.avatar-uploader .el-upload:hover {
border-color: #409EFF;
}
.avatar-uploader-icon {
font-size: 28px;
color: #8c939d;
width: 280px;
height: 178px;
line-height: 178px;
text-align: center;
}
.avatar {
width: 280px;
height: 178px;
display: block;
}
}
</style>