2024-07-29 11:08:00 +08:00
|
|
|
<template>
|
2024-08-29 18:27:08 +08:00
|
|
|
|
2024-09-04 22:16:24 +08:00
|
|
|
<div class="tab-boxs" style="justify-content: space-between">
|
2024-07-29 11:08:00 +08:00
|
|
|
<!-- left -->
|
2024-09-04 22:16:24 +08:00
|
|
|
<div class="d-s" style="width: 20%" @click="toHome">
|
2024-07-29 11:08:00 +08:00
|
|
|
<div class="logo-box">
|
|
|
|
<img :src="baseInfo.webImg" />
|
|
|
|
</div>
|
|
|
|
<div class="logo-size">
|
|
|
|
{{ this.baseInfo.webName }}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<!-- tab -->
|
2024-09-04 22:16:24 +08:00
|
|
|
<div class="d-s" style="width: 68%;justify-content: space-between">
|
2024-08-17 15:19:21 +08:00
|
|
|
<div class="x-x" :class="{'active' :tabindex == index }" v-for="(item, index) in tablist " :key="index" @click="tabClick(item.jumpUrl, item.id,index)" >
|
2024-08-20 10:15:30 +08:00
|
|
|
<div>
|
2024-08-20 14:24:27 +08:00
|
|
|
<img v-if="item.iconUrl" :src=" imgurl +item.iconUrl " alt="" style="width: 25px;height: 25px">
|
2024-08-20 10:15:30 +08:00
|
|
|
</div>
|
2024-08-20 14:24:27 +08:00
|
|
|
<div class="bsize">{{ item.label }}</div>
|
2024-07-29 11:08:00 +08:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<!-- right -->
|
2024-09-04 22:16:24 +08:00
|
|
|
<!-- <div class="d-s" style="font-size: 20px; color: #fff;cursor: pointer;width: 170px;justify-content: flex-end">-->
|
2024-08-01 19:19:11 +08:00
|
|
|
<!-- <i class="el-icon-search" v-if="show_search"></i>-->
|
|
|
|
<!-- <div style="font-size: 18px; margin-left: 15px; " v-if="show_search" @click="show_search = !show_search">搜索-->
|
|
|
|
<!-- </div>-->
|
|
|
|
<!-- <el-input placeholder="输入关键词" v-model="input" style="width: 150px;height: 35px" v-if="!show_search">-->
|
|
|
|
<!-- <i slot="prefix" class="el-input__icon el-icon-search"></i>-->
|
|
|
|
<!-- </el-input>-->
|
|
|
|
<!-- <i class="el-icon-circle-close" v-if="!show_search" style="margin-left: 10px;"-->
|
|
|
|
<!-- @click="show_search = true"></i>-->
|
2024-09-04 22:16:24 +08:00
|
|
|
<!-- </div>-->
|
2024-08-30 23:50:45 +08:00
|
|
|
<div class="right-box" v-if="!isLoggedIn">
|
2024-08-29 00:00:57 +08:00
|
|
|
<el-button class="login-button" @click="showLoginDialog = true">登录</el-button>
|
|
|
|
<el-button class="register-button" @click="registerDialog = true">注册</el-button>
|
|
|
|
</div>
|
2024-08-30 23:50:45 +08:00
|
|
|
<div class="right-box" v-if="isLoggedIn">
|
2024-08-29 00:00:57 +08:00
|
|
|
<el-dropdown @command="handleCommand">
|
|
|
|
<span class="right-box">
|
|
|
|
{{ currentUser }} <i class="el-icon-arrow-down el-icon--right"></i>
|
|
|
|
</span>
|
|
|
|
<el-dropdown-menu slot="dropdown">
|
|
|
|
<el-dropdown-item command="logout" divided @click.native="logout" >退出登录</el-dropdown-item>
|
|
|
|
</el-dropdown-menu>
|
|
|
|
</el-dropdown>
|
|
|
|
</div>
|
|
|
|
<el-dialog title="登录" :visible.sync="showLoginDialog" width="30%" :modal="false">
|
|
|
|
<div>
|
|
|
|
<el-form :model="loginForm" ref="loginForm">
|
|
|
|
<el-form-item prop="username">
|
2024-09-06 18:02:02 +08:00
|
|
|
<el-input placeholder="手机号" v-model="loginForm.username" ></el-input>
|
2024-08-29 00:00:57 +08:00
|
|
|
</el-form-item>
|
|
|
|
<el-form-item prop="password">
|
|
|
|
<el-input placeholder="密码" v-model="loginForm.password" type="password"></el-input>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item prop="code">
|
2024-08-29 18:27:08 +08:00
|
|
|
<el-input v-model="loginForm.code"
|
2024-08-29 00:00:57 +08:00
|
|
|
auto-complete="off"
|
|
|
|
placeholder="验证码"
|
|
|
|
style="width: 63%"
|
|
|
|
@keyup.enter.native="handleLogin">
|
|
|
|
<svg-icon slot="prefix" icon-class="validCode" class="el-input__icon input-icon" />
|
|
|
|
</el-input>
|
|
|
|
<div class="login-code">
|
|
|
|
<img :src="codeUrl" @click="getCode" class="login-code-img"/>
|
|
|
|
</div>
|
|
|
|
</el-form-item>
|
|
|
|
<el-checkbox v-model="loginForm.rememberMe" style="margin:0px 0px 25px 0px;">记住密码</el-checkbox>
|
|
|
|
</el-form>
|
|
|
|
</div>
|
|
|
|
<span slot="footer" class="dialog-footer">
|
|
|
|
<el-button @click="showLoginDialog = false">取 消</el-button>
|
|
|
|
<el-button type="primary" @click="submitLogin">登 录</el-button>
|
|
|
|
</span>
|
|
|
|
</el-dialog>
|
2024-08-29 18:27:08 +08:00
|
|
|
<el-dialog title="注册" :close-on-click-modal="false" :visible.sync="registerDialog" width="30%" :modal="false">
|
|
|
|
<div>
|
2024-08-29 00:00:57 +08:00
|
|
|
<el-form :model="registerForm" :rules="registerRules" ref="registerForm">
|
2024-08-29 18:27:08 +08:00
|
|
|
<el-form-item prop="userType">
|
|
|
|
<el-radio-group v-model="registerForm.userType">
|
|
|
|
<el-radio label="01">学生</el-radio>
|
|
|
|
<el-radio label="02">指导老师</el-radio>
|
|
|
|
<el-radio label="03">领队老师</el-radio>
|
|
|
|
</el-radio-group>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item prop="nickName" >
|
|
|
|
<el-input placeholder="姓名" v-model="registerForm.nickName" type="text"></el-input>
|
|
|
|
</el-form-item>
|
2024-08-29 00:00:57 +08:00
|
|
|
<el-form-item prop="username">
|
2024-09-06 18:02:02 +08:00
|
|
|
<el-input placeholder="手机号(登录账号)" v-model="registerForm.username" type="text"></el-input>
|
2024-08-29 00:00:57 +08:00
|
|
|
</el-form-item>
|
2024-08-29 18:27:08 +08:00
|
|
|
|
2024-08-29 00:00:57 +08:00
|
|
|
<el-form-item prop="password">
|
|
|
|
<el-input placeholder="密码" v-model="registerForm.password" type="password"></el-input>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item prop="confirmPassword">
|
|
|
|
<el-input placeholder="确认密码" v-model="registerForm.confirmPassword" type="password"></el-input>
|
|
|
|
</el-form-item>
|
2024-08-29 18:27:08 +08:00
|
|
|
<el-form-item prop="hitRegistrationTeachInfo.teacherEmail" v-if="registerForm.userType=='03'||registerForm.userType=='02'">
|
|
|
|
<el-input placeholder="邮箱" v-model="registerForm.hitRegistrationTeachInfo.teacherEmail" type="text"></el-input>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item prop="hitRegistrationTeachInfo.teacherNumber" v-if="registerForm.userType=='03'||registerForm.userType=='02'">
|
|
|
|
<el-input placeholder="手机号" v-model="registerForm.hitRegistrationTeachInfo.teacherNumber" type="text"></el-input>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item prop="hitRegistrationTeachInfo.division" v-if="registerForm.userType=='03'||registerForm.userType=='02'">
|
|
|
|
<el-select v-model="registerForm.hitRegistrationTeachInfo.division" filterable allow-create default-first-option
|
|
|
|
placeholder="请选择赛区">
|
|
|
|
<el-option v-for="item in dict.type.com_region" :key="item.value" :label="item.label"
|
|
|
|
:value="item.value">
|
|
|
|
</el-option>
|
|
|
|
</el-select>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item prop="hitRegistrationTeachInfo.schoolName" v-if="registerForm.userType=='03'||registerForm.userType=='02'">
|
|
|
|
<el-select v-model="registerForm.hitRegistrationTeachInfo.schoolName" filterable allow-create default-first-option
|
|
|
|
placeholder="请选择学校名称">
|
|
|
|
<el-option v-for="item in dict.type.school_name" :key="item.value" :label="item.label"
|
|
|
|
:value="item.value">
|
|
|
|
</el-option>
|
|
|
|
</el-select>
|
|
|
|
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item prop="hitRegistrationTeachInfo.teacherSchool" v-if="registerForm.userType=='03'||registerForm.userType=='02'">
|
|
|
|
<el-input placeholder="所在系及专业" v-model="registerForm.hitRegistrationTeachInfo.teacherSchool" type="text"></el-input>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item prop="hitRegistrationTeachInfo.teacherJob" v-if="registerForm.userType=='03'||registerForm.userType=='02'">
|
2024-08-29 00:00:57 +08:00
|
|
|
<el-input placeholder="职务" v-model="registerForm.hitRegistrationTeachInfo.teacherJob" type="text"></el-input>
|
|
|
|
</el-form-item>
|
2024-08-29 18:27:08 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2024-08-29 00:00:57 +08:00
|
|
|
<el-form-item prop="code" >
|
2024-08-29 18:27:08 +08:00
|
|
|
<el-input v-model="registerForm.code"
|
2024-08-29 00:00:57 +08:00
|
|
|
auto-complete="off"
|
|
|
|
placeholder="验证码"
|
|
|
|
style="width: 63%"
|
|
|
|
@keyup.enter.native="handleLogin">
|
|
|
|
<svg-icon slot="prefix" icon-class="validCode" class="el-input__icon input-icon" />
|
|
|
|
</el-input>
|
|
|
|
<div class="login-code">
|
|
|
|
<img :src="codeUrl" @click="getCode" class="login-code-img"/>
|
|
|
|
</div>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item></el-form-item>
|
|
|
|
</el-form>
|
|
|
|
</div>
|
|
|
|
<span slot="footer" class="dialog-footer">
|
|
|
|
<el-button @click="showRegisterDialog = false">取 消</el-button>
|
|
|
|
<el-button type="primary" @click="submitRegister">注 册</el-button>
|
|
|
|
</span>
|
|
|
|
</el-dialog>
|
2024-07-29 11:08:00 +08:00
|
|
|
</div>
|
2024-08-29 18:27:08 +08:00
|
|
|
|
2024-07-29 11:08:00 +08:00
|
|
|
</template>
|
|
|
|
<script>
|
2024-08-29 00:00:57 +08:00
|
|
|
import { getHomeUserInfo ,getTeacherAndStudentInfo} from "@/api/system/user";
|
2024-08-05 17:02:01 +08:00
|
|
|
import { getBaseInfo, getTab } from '@/api/gw/home'
|
2024-08-29 00:00:57 +08:00
|
|
|
import { getCodeImg ,register} from "@/api/login";
|
|
|
|
import Cookies from "js-cookie";
|
|
|
|
import { encrypt, decrypt } from '@/utils/jsencrypt'
|
2024-08-30 23:50:45 +08:00
|
|
|
import { getToken } from "@/utils/auth";
|
2024-07-29 11:08:00 +08:00
|
|
|
export default {
|
2024-08-29 18:27:08 +08:00
|
|
|
dicts: ["sys_user_sex", "school_name","com_region"],
|
2024-07-29 11:08:00 +08:00
|
|
|
data() {
|
2024-08-29 18:27:08 +08:00
|
|
|
|
2024-08-29 00:00:57 +08:00
|
|
|
const equalToPassword = (rule, value, callback) => {
|
|
|
|
if (this.registerForm.password !== value) {
|
|
|
|
callback(new Error("两次输入的密码不一致"));
|
|
|
|
} else {
|
|
|
|
callback();
|
|
|
|
}
|
|
|
|
};
|
2024-07-29 11:08:00 +08:00
|
|
|
return {
|
2024-08-29 00:00:57 +08:00
|
|
|
isLoggedIn: false, // 是否登录
|
|
|
|
value: false,
|
|
|
|
currentUser: '', //当前用户
|
|
|
|
codeUrl: "", //验证码地址
|
|
|
|
showLoginDialog: false, // 是否显示登录对话框
|
|
|
|
registerDialog: false, // 是否显示注册对话框
|
2024-07-29 11:08:00 +08:00
|
|
|
baseInfo:"",
|
2024-08-20 10:15:30 +08:00
|
|
|
imgurl: process.env.VUE_APP_BASE_API,
|
2024-07-29 11:08:00 +08:00
|
|
|
input:'',
|
|
|
|
show_search: true,
|
2024-07-29 16:50:33 +08:00
|
|
|
categoryQuery:{},
|
2024-08-17 15:19:21 +08:00
|
|
|
tabindex:0,
|
2024-07-29 11:08:00 +08:00
|
|
|
tablist: [
|
|
|
|
{name: '首页'},
|
|
|
|
{name: '中心概括'},
|
|
|
|
{name: '教学资源'},
|
|
|
|
{name: '教学平台'},
|
|
|
|
{name: '教学团队'},
|
|
|
|
{name: '专业委员会'},
|
|
|
|
{name: '教学研讨活动'},
|
|
|
|
{name: '虚仿专业频道'},
|
|
|
|
{name: '大赛风采'},
|
|
|
|
{name: '实践平台'},
|
|
|
|
{name: '合作企业'},
|
|
|
|
{name: '联系我们'},
|
|
|
|
],
|
2024-08-29 00:00:57 +08:00
|
|
|
loginForm: {
|
|
|
|
username: '',
|
|
|
|
password: '',
|
|
|
|
code: '',
|
|
|
|
uuid: '',
|
|
|
|
rememberMe: false
|
|
|
|
|
|
|
|
},
|
|
|
|
registerForm: {
|
|
|
|
username: '',
|
|
|
|
password: '',
|
|
|
|
code: '',
|
|
|
|
confirmPassword: '',
|
|
|
|
uuid: '',
|
2024-08-29 18:27:08 +08:00
|
|
|
userType:'01',
|
2024-08-29 00:00:57 +08:00
|
|
|
hitRegistrationTeachInfo:{
|
|
|
|
teacherName: '',
|
|
|
|
teacherJob: '',
|
|
|
|
teacherEmail: '',
|
|
|
|
teacherNumber: '',
|
|
|
|
teacherSchool: '',
|
|
|
|
schoolName: '',
|
|
|
|
division: '',
|
|
|
|
SampleAddress: '',
|
2024-08-29 18:27:08 +08:00
|
|
|
|
2024-08-29 00:00:57 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
registerRules: {
|
|
|
|
username: [
|
|
|
|
{ required: true, trigger: "blur", message: "请输入您的账号" },
|
|
|
|
{ message: '学号不能为空', trigger: 'blur' }
|
|
|
|
],
|
2024-08-29 18:27:08 +08:00
|
|
|
nickName: [
|
|
|
|
{ required: true, trigger: "blur", message: "请输入您的姓名" },
|
|
|
|
{ message: '姓名不能为空', trigger: 'blur' }
|
|
|
|
],
|
2024-08-29 00:00:57 +08:00
|
|
|
password: [
|
|
|
|
{ required: true, trigger: "blur", message: "请输入您的密码" },
|
|
|
|
{ min: 5, max: 20, message: "用户密码长度必须介于 5 和 20 之间", trigger: "blur" },
|
|
|
|
{ pattern: /^[^<>"'|\\]+$/, message: "不能包含非法字符:< > \" ' \\\ |", trigger: "blur" }
|
|
|
|
],
|
|
|
|
confirmPassword: [
|
|
|
|
{ required: true, trigger: "blur", message: "请再次输入您的密码" },
|
|
|
|
{ required: true, validator: equalToPassword, trigger: "blur" }
|
|
|
|
],
|
2024-08-29 18:27:08 +08:00
|
|
|
code: [{ required: true, trigger: "change", message: "请输入验证码" }],
|
|
|
|
'hitRegistrationTeachInfo.teacherEmail': [
|
|
|
|
{ required: true, trigger: "blur", message: "请输入您的邮箱" },
|
|
|
|
],
|
|
|
|
'hitRegistrationTeachInfo.teacherNumber': [
|
|
|
|
{ required: true, trigger: "blur", message: "请输入您的手机号" },
|
|
|
|
],
|
|
|
|
'hitRegistrationTeachInfo.division': [
|
|
|
|
{ required: true, trigger: "blur", message: "请选择赛区" },
|
|
|
|
],
|
|
|
|
'hitRegistrationTeachInfo.schoolName': [
|
|
|
|
{ required: true, trigger: "blur", message: "请选择学校名称" },
|
|
|
|
],
|
|
|
|
'hitRegistrationTeachInfo.teacherSchool': [
|
|
|
|
{ required: true, trigger: "blur", message: "请输入所在系及专业" },
|
|
|
|
],
|
|
|
|
'hitRegistrationTeachInfo.teacherJob': [
|
|
|
|
{ required: true, trigger: "blur", message: "请输入您的职务" },
|
|
|
|
],
|
2024-08-29 00:00:57 +08:00
|
|
|
}
|
2024-07-29 11:08:00 +08:00
|
|
|
}
|
|
|
|
},
|
2024-08-17 15:19:21 +08:00
|
|
|
props: {
|
|
|
|
msg: String
|
|
|
|
},
|
|
|
|
created() {
|
|
|
|
this.tabindex = this.msg
|
2024-08-29 00:00:57 +08:00
|
|
|
this.getCode();
|
|
|
|
this.getCookie(); // 页面加载完毕调用
|
2024-08-30 23:50:45 +08:00
|
|
|
this.isLoggedIn = getToken()?true:false; // 检查 localStorage 中的登录状态
|
2024-08-29 00:00:57 +08:00
|
|
|
if (this.isLoggedIn) {
|
|
|
|
this.loadUserInfo();
|
|
|
|
}
|
2024-08-17 15:19:21 +08:00
|
|
|
},
|
2024-07-29 11:08:00 +08:00
|
|
|
mounted() {
|
2024-08-17 15:19:21 +08:00
|
|
|
this.tabindex = this.msg
|
2024-08-29 00:00:57 +08:00
|
|
|
// console.log(this.msg)
|
2024-07-29 11:08:00 +08:00
|
|
|
// 页面加载完毕调用
|
|
|
|
this.tabLsit();
|
2024-08-29 00:00:57 +08:00
|
|
|
this.getWebBaseInfo();
|
2024-08-29 00:13:54 +08:00
|
|
|
// 监听窗口关闭事件
|
|
|
|
window.addEventListener('beforeunload', this.handleBeforeUnload);
|
|
|
|
},
|
|
|
|
beforeDestroy() {
|
|
|
|
// 组件销毁前移除事件监听
|
|
|
|
window.removeEventListener('beforeunload', this.handleBeforeUnload);
|
2024-07-29 11:08:00 +08:00
|
|
|
},
|
2024-08-29 18:27:08 +08:00
|
|
|
|
2024-07-29 11:08:00 +08:00
|
|
|
methods:{
|
2024-08-29 18:27:08 +08:00
|
|
|
|
2024-08-29 00:00:57 +08:00
|
|
|
//用户信息
|
|
|
|
loadUserInfo() {
|
|
|
|
getHomeUserInfo().then(response => {
|
|
|
|
this.currentUser = response.data.userName;
|
2024-08-29 18:27:08 +08:00
|
|
|
console.log('当前用户名:', this.currentUser);
|
2024-08-29 00:00:57 +08:00
|
|
|
if (this.userInfo.avatar && this.userInfo.avatar != '') {
|
|
|
|
this.userInfo.avatar = process.env.VUE_APP_BASE_API + this.userInfo.avatar;
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
//验证码
|
|
|
|
getCode() {
|
|
|
|
getCodeImg().then(res => {
|
|
|
|
this.captchaEnabled = res.captchaEnabled === undefined ? true : res.captchaEnabled;
|
|
|
|
if (this.captchaEnabled) {
|
|
|
|
this.codeUrl = "data:image/gif;base64," + res.img;
|
|
|
|
this.loginForm.uuid = res.uuid;
|
|
|
|
this.registerForm.uuid = res.uuid;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
getCookie() {
|
|
|
|
const username = Cookies.get("username");
|
|
|
|
const password = Cookies.get("password");
|
|
|
|
const rememberMe = Cookies.get('rememberMe')
|
|
|
|
this.loginForm = {
|
|
|
|
username: username === undefined ? this.loginForm.username : username,
|
|
|
|
password: password === undefined ? this.loginForm.password : decrypt(password),
|
|
|
|
rememberMe: rememberMe === undefined ? false : Boolean(rememberMe)
|
|
|
|
};
|
|
|
|
},
|
|
|
|
// 登录
|
|
|
|
submitLogin() {
|
|
|
|
this.$refs.loginForm.validate(valid => {
|
|
|
|
if (valid) {
|
|
|
|
this.loading = true;
|
|
|
|
if (this.loginForm.rememberMe) {
|
|
|
|
Cookies.set("username", this.loginForm.username, { expires: 30 });
|
|
|
|
Cookies.set("password", encrypt(this.loginForm.password), { expires: 30 });
|
|
|
|
Cookies.set('rememberMe', this.loginForm.rememberMe, { expires: 30 });
|
|
|
|
} else {
|
|
|
|
Cookies.remove("username");
|
|
|
|
Cookies.remove("password");
|
|
|
|
Cookies.remove('rememberMe');
|
|
|
|
}
|
|
|
|
this.$store.dispatch("Login", this.loginForm).then(() => {
|
|
|
|
this.isLoggedIn = true; // 登录成功后设置标志
|
|
|
|
this.showLoginDialog = false;
|
|
|
|
this.$router.push("/virtually").catch(()=>{});
|
|
|
|
this.loadUserInfo();
|
|
|
|
localStorage.setItem('isLoggedIn', 'true'); // 将登录状态存储在 localStorage
|
2024-08-29 18:27:08 +08:00
|
|
|
console.log('当前用户名:', this.currentUser);
|
2024-08-29 00:00:57 +08:00
|
|
|
}).catch(() => {
|
|
|
|
this.loading = false;
|
|
|
|
if (this.captchaEnabled) {
|
|
|
|
this.getCode();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
},
|
|
|
|
//注册
|
|
|
|
submitRegister() {
|
|
|
|
this.$refs.registerForm.validate(valid => {
|
|
|
|
if (valid) {
|
2024-09-06 18:02:02 +08:00
|
|
|
// 验证用户名是否为手机号
|
|
|
|
const phoneRegex = /^1[3-9]\d{9}$/;
|
|
|
|
if (!phoneRegex.test(this.registerForm.username)) {
|
|
|
|
this.$alert("<font color='red'>请输入有效的手机号。</font>", '系统提示', {
|
|
|
|
dangerouslyUseHTMLString: true,
|
|
|
|
type: 'error'
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-08-29 00:00:57 +08:00
|
|
|
this.loading = true;
|
|
|
|
register(this.registerForm).then(res => {
|
|
|
|
const username = this.registerForm.username;
|
2024-09-06 18:02:02 +08:00
|
|
|
this.registerDialog = false;
|
2024-08-29 00:00:57 +08:00
|
|
|
this.$alert("<font color='red'>恭喜你,您的账号 " + username + " 注册成功!</font>", '系统提示', {
|
|
|
|
dangerouslyUseHTMLString: true,
|
|
|
|
type: 'success'
|
|
|
|
}).then(() => {
|
|
|
|
this.$router.push("/virtually");
|
2024-09-06 18:02:02 +08:00
|
|
|
}).catch(() => { });
|
2024-08-29 00:00:57 +08:00
|
|
|
}).catch(() => {
|
|
|
|
this.loading = false;
|
|
|
|
if (this.captchaEnabled) {
|
|
|
|
this.getCode();
|
|
|
|
}
|
2024-09-06 18:02:02 +08:00
|
|
|
});
|
2024-08-29 00:00:57 +08:00
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
//退出登录
|
|
|
|
async logout() {
|
|
|
|
this.$confirm('确定注销并退出系统吗?', '提示', {
|
|
|
|
confirmButtonText: '确定',
|
|
|
|
cancelButtonText: '取消',
|
|
|
|
type: 'warning'
|
|
|
|
}).then(() => {
|
|
|
|
this.$store.dispatch('LogOut').then(() => {
|
|
|
|
localStorage.removeItem('isLoggedIn'); // 清空 localStorage 中的登录状态
|
|
|
|
location.href = '/index';
|
|
|
|
})
|
|
|
|
}).catch(() => {});
|
2024-08-29 00:13:54 +08:00
|
|
|
},
|
|
|
|
// 定义处理窗口关闭前的事件
|
|
|
|
handleBeforeUnload() {
|
|
|
|
// 清空localStorage中的isLoggedIn
|
|
|
|
localStorage.removeItem('isLoggedIn');
|
2024-08-29 00:00:57 +08:00
|
|
|
},
|
2024-08-17 15:19:21 +08:00
|
|
|
tabClick(url,id,index){
|
|
|
|
this.tabindex = index
|
2024-07-31 18:04:00 +08:00
|
|
|
if (url === 'home') url = "gw";
|
2024-07-29 14:30:06 +08:00
|
|
|
this.$router.push({
|
|
|
|
name: url,
|
2024-07-29 16:15:31 +08:00
|
|
|
query:{ id: id }
|
2024-07-29 14:30:06 +08:00
|
|
|
});
|
|
|
|
|
2024-07-29 11:08:00 +08:00
|
|
|
},
|
|
|
|
tabLsit() {
|
|
|
|
getTab().then(response => {
|
|
|
|
if (response.code == 200) {
|
|
|
|
this.tablist = response.data;
|
|
|
|
this.categoryQuery.categoryId = this.tablist[0].id
|
|
|
|
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
getWebBaseInfo() {
|
|
|
|
getBaseInfo().then(res => {
|
|
|
|
this.baseInfo = res.data
|
|
|
|
this.baseInfo.webImg = process.env.VUE_APP_BASE_API + this.baseInfo.webImg
|
|
|
|
})
|
2024-08-04 17:31:55 +08:00
|
|
|
},
|
|
|
|
toHome(){
|
|
|
|
this.$router.push("/virtually")
|
2024-08-29 00:00:57 +08:00
|
|
|
},
|
2024-07-29 11:08:00 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
<style scoped lang="scss">
|
2024-08-29 00:00:57 +08:00
|
|
|
.right-box {
|
|
|
|
display: flex;
|
|
|
|
justify-content: center;
|
|
|
|
align-items: center;
|
|
|
|
width: 170px;
|
|
|
|
font-size: 20px;
|
|
|
|
color: #fff;
|
|
|
|
cursor: pointer;
|
|
|
|
}
|
|
|
|
|
|
|
|
.login-button {
|
|
|
|
background-color: #fff; /* 白色背景 */
|
|
|
|
color: #005375; /* 蓝色文字 */
|
|
|
|
}
|
|
|
|
|
|
|
|
.register-button {
|
|
|
|
background: none; /* 透明背景 */
|
|
|
|
color: #fff; /* 白色文字 */
|
|
|
|
}
|
|
|
|
|
2024-08-17 15:19:21 +08:00
|
|
|
.tab-boxs {
|
2024-07-29 11:08:00 +08:00
|
|
|
width: 100%;
|
|
|
|
box-sizing: border-box;
|
2024-08-17 15:19:21 +08:00
|
|
|
padding: 0px 50px;
|
2024-07-29 11:08:00 +08:00
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: space-between;
|
|
|
|
border-bottom: 1px solid rgba(255, 255, 255, 0.2);;
|
|
|
|
font-weight: bold;
|
|
|
|
font-size: 18px;
|
|
|
|
color: #FFFFFF;
|
|
|
|
position: absolute;
|
|
|
|
z-index: 3;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
.d-s {
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
2024-08-04 17:31:55 +08:00
|
|
|
cursor: pointer;
|
2024-07-29 11:08:00 +08:00
|
|
|
}
|
|
|
|
.logo-box {
|
|
|
|
width: 50px;
|
|
|
|
height: 50px;
|
|
|
|
background: #fff;
|
|
|
|
}
|
|
|
|
.logo-box img{
|
|
|
|
width: 50px;
|
|
|
|
height: 50px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.logo-size {
|
2024-08-20 14:24:27 +08:00
|
|
|
font-weight: 600;
|
|
|
|
font-size: 22px;
|
2024-07-29 11:08:00 +08:00
|
|
|
color: #FFFFFF;
|
|
|
|
margin-left: 20px;
|
|
|
|
|
|
|
|
}
|
|
|
|
.x-x {
|
|
|
|
cursor: pointer;
|
2024-08-17 15:19:21 +08:00
|
|
|
height: 90px;
|
2024-08-20 14:24:27 +08:00
|
|
|
text-align: center;
|
2024-08-20 10:15:30 +08:00
|
|
|
box-sizing: border-box;
|
2024-08-20 14:24:27 +08:00
|
|
|
padding-top: 25px;
|
2024-08-17 15:19:21 +08:00
|
|
|
}
|
|
|
|
.x-x:hover{
|
|
|
|
background: linear-gradient( 360deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0) 100%);
|
|
|
|
//border-bottom: 2px solid #fff;
|
|
|
|
}
|
|
|
|
.active{
|
|
|
|
background: linear-gradient( 360deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0) 100%);
|
|
|
|
border-bottom: 2px solid #fff !important;
|
2024-07-29 11:08:00 +08:00
|
|
|
}
|
2024-08-20 14:24:27 +08:00
|
|
|
.bsize{
|
|
|
|
font-weight: 500;
|
|
|
|
font-size: 16px;
|
|
|
|
color: #FFFFFF;
|
|
|
|
}
|
2024-08-29 00:00:57 +08:00
|
|
|
.login-code {
|
|
|
|
width: 33%;
|
|
|
|
height: 38px;
|
|
|
|
float: right;
|
|
|
|
img {
|
|
|
|
cursor: pointer;
|
|
|
|
vertical-align: middle;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.login-code-img {
|
|
|
|
height: 38px;
|
|
|
|
}
|
2024-08-29 18:27:08 +08:00
|
|
|
.el-dialog__title {
|
|
|
|
text-align: center;
|
2024-08-29 00:00:57 +08:00
|
|
|
}
|
|
|
|
|
2024-07-29 11:08:00 +08:00
|
|
|
</style>
|