Files
zhxg_xsbdV1.0/pages/login/index.vue

392 lines
466 KiB
Vue
Raw Normal View History

2025-07-16 17:44:45 +08:00
<template>
<view>
<view class="background">
<view class="front">
<view class="front-form">
<view class="logo">
<image src="../../static/logo.png" mode="aspectFit"></image>
<text class="title">新生报到系统</text>
</view>
<view class="front-form-text">
<!-- 账号登录 -->
</view>
<view class="front-form-input">
<input type="text" v-model="username" placeholder="请输入考生号">
</view>
<view class="front-form-input">
<input type="password" v-model="password" placeholder="请输入密码">
</view>
<view class="front-form-button">
<button @click="doLogin">登录</button>
</view>
<view class="front-form-text">
<text @click="topwd">
忘记密码
</text>
</view>
<view class="front-help">
<text @click="toHelpPage"
style="font-size: 40rpx;font-family: ui-rounded;font-weight: 800;">登录前请查看操作手册</text>
</view>
</view>
</view>
</view>
<!-- <uni-popup class="popup-check" ref="inputDialog" type="dialog">
<view style="background-color: white;width: 570rpx;padding:10rpx 54rpx;border-radius: 20rpx;">
<view class="row">
请输入以下信息进行账号激活
</view>
<view class="row">
<input v-model="actForm.SFZH" class="uni-input" focus placeholder="身份证号" />
</view>
<view class="row">
<input v-model="actForm.KSH" class="uni-input" focus placeholder="考生号" />
</view>
<view class="row phone">
<input v-model="actForm.SJH" :disabled="true" class="uni-input" focus placeholder="高考预留手机号" />
<button @click="editPhone" class="mini-btn" type="primary" size="mini">更换手机号</button>
</view>
<view class="row code">
<input v-model="actForm.code" class="uni-input" focus placeholder="手机验证码" />
<button @click="doSend" class="mini-btn" type="primary" :disabled="can_send"
size="mini">{{code_text}}</button>
</view>
<view class="row btns" style="padding: 20rpx 10rpx 20rpx 10rpx ;">
<button class="activate" @tap="doAct">激活</button>
<button class="activate" @tap="exit">退出</button>
</view>
</view>
</uni-popup> -->
<u-toast ref="uToast" @show="submit"></u-toast>
</view>
</template>
<script>
import {
isEmpty
} from "@/api/helpFunc.js";
import {
doLogin,
getOwnInfo,
getUserInfo,
doAct,
doSendMsg
} from "@/api/validApi.js";
import {
setInfo,
logOut
} from "@/middleware/storage.js";
export default {
data() {
return {
// imgSrc: 'https://wap.wzzyhp.com//profile/uniapp/static/bg.png',
username: "",
password: "",
msgType: null,
messageText: "",
submit: false,
code_text: "获取验证码",
is_send: 60,
can_send: false,
stu_no: "",
actForm: {
KSH: "",
SFZH: "",
SJH: "",
code: ""
},
sfzh: ""
}
},
onShow() {
//this.$refs.inputDialog.close();
},
methods: {
editPhone() {
uni.setStorageSync("ksh", this.username)
uni.setStorageSync("loginInfo", {
username: this.username,
password: this.password
});
uni.navigateTo({
url: "/pages/login/editphone"
})
},
exit() {
this.$refs.inputDialog.close();
},
async doAct() {
const requiredFields = {
SFZH: '身份证号不能为空',
KSH: "考生号不能为空",
SJH: "手机号不能为空",
code: '验证码不能为空'
};
//检验非空
const emptyField = Object.keys(requiredFields).find(field => this.actForm[field] === "");
if (emptyField) {
uni.showToast({
title: requiredFields[emptyField], // 显示对应字段的提示信息
icon: "none"
});
return;
}
this.actForm.KSH = this.username;
let sdata = {
...this.actForm
};
let res = await doAct(sdata);
if (res.msg == "200") {
this.$refs.inputDialog.close();
this.$refs.uToast.show({
type: "success",
message: "激活成功,请点击登录",
duration: 1500,
});
} else {
this.$refs.uToast.show({
type: "error",
message: res.msg,
duration: 1500,
})
}
},
toHelpPage() {
uni.navigateTo({
url: "/pages/help/helpword"
})
},
async doSend() {
let sdata = {
KSH: this.username,
SFZH: this.actForm.SFZH,
SJH: this.actForm.SJH
};
let res = await doSendMsg(sdata);
if (res.code == 200) {
this.$refs.uToast.show({
type: "success",
message: res.msg,
duration: 1500,
});
let tick = setInterval(() => {
this.is_send -= 1;
this.can_send = true;
this.code_text = this.is_send + "s";
if (this.is_send == 0) {
this.code_text = "获取验证码";
this.is_send = 60;
this.can_send = false;
clearInterval(tick);
}
}, 1000);
} else {
this.$refs.uToast.show({
type: "error",
message: res.msg,
duration: 1500,
})
}
},
async topwd() {
uni.navigateTo({
url: "/pages/update_pwd/update_pwd"
})
},
async doLogin() {
if (isEmpty(this.username) || isEmpty(this.password)) {
this.msgType = "error"
this.messageText = `不能为空`;
uni.showToast({
title: "考生号或密码不能为空",
icon: "none"
});
// this.$refs.message.open();
return;
}
let sdata = {
username: this.username,
password: this.password
}
let res = await doLogin(sdata);
if (res.code != 200) {
this.$refs.uToast.show({
type: "error",
message: res.msg,
duration: 1500,
})
return;
} else {
// if (res.regStatus == "0") {
// this.$refs.inputDialog.open();
// getOwnInfo(this.username).then(res => {
// console.log(res);
// this.actForm.SJH = res.data.sjh;
// this.actForm.KSH = res.data.ksh;
// this.sfzh = res.data.sfzh;
// })
// } else {
uni.setStorageSync("token", res.token);
uni.redirectTo({
url: "/pages/newindex/newindex"
});
// }
}
}
}
}
</script>
<style scoped lang="scss">
.popup-check {
.row {
padding: 40rpx 5rpx 40rpx 5rpx;
border-bottom: 1rpx solid lightgray;
font-size: 40rpx;
&.btns {
display: flex;
button {
flex: 1;
&:last-child {
background-color: white;
color: #007AFF;
border: 1px solid #007AFF;
}
&:first-child {
margin-right: 10px;
flex: 3;
}
}
}
&:first-child {
text-align: center;
}
&:last-child {
border-bottom: none;
}
&.phone,
&.code {
display: flex;
justify-content: space-between;
input {
flex: 1;
}
}
.activate {
background-color: #007AFF;
color: white;
margin: 20px 0;
}
}
}
.background {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: url("
}
.imgSrc {
height: 100%;
width: 100%;
}
.front {
width: 100%;
height: 100vh;
z-index: 1;
position: absolute;
.logo {
display: flex;
flex-direction: column;
justify-content: space-between;
align-items: center;
margin-bottom: 100rpx;
.title {
font-weight: bold;
font-size: 48rpx;
margin-top: 10px;
font-family: douyin;
}
image {
width: 200rpx;
height: 200rpx;
margin-bottom: 20rpx;
}
text {
color: #404040;
}
}
.front-top {
margin: 20rpx 80rpx 20rpx 80rpx;
padding-top: 180rpx;
}
.front-form {
margin: 200rpx 80rpx 20rpx 80rpx;
.front-form-text {
// font-size: 0.8rem;
// margin-bottom: 20rpx;
display: flex;
justify-content: center;
align-items: center;
text {
color: red;
font-size: 30rpx;
}
}
.front-form-input {
margin: 40rpx 0;
input {
border: 1px solid #DCDFE6;
background-color: white;
height: 1.5rem;
padding: 10px;
border-radius: 40rpx;
}
}
.front-form-button {
margin: 80rpx 0 40rpx;
button {
background-color: #0081FF;
color: white;
border-radius: 40rpx;
}
}
.front-help {
margin-top: 40rpx;
font-size: 0.8rem;
text-align: center;
}
}
}
</style>