'admin-21.02.14:新增个人中心、返回顶部、封装js、优化布局等'
This commit is contained in:
parent
b1d3acdd54
commit
74e8926177
@ -16,7 +16,7 @@ import {
|
|||||||
} from "vue";
|
} from "vue";
|
||||||
import { useStore } from "/@/store/index.ts";
|
import { useStore } from "/@/store/index.ts";
|
||||||
import { getLocal } from "/@/utils/storage.ts";
|
import { getLocal } from "/@/utils/storage.ts";
|
||||||
import { setIconfont } from "/@/utils/setIconfont.ts";
|
import setIntroduction from "/@/utils/setIconfont.ts";
|
||||||
import LockScreen from "/@/views/layout/lockScreen/index.vue";
|
import LockScreen from "/@/views/layout/lockScreen/index.vue";
|
||||||
import Setings from "/@/views/layout/navBars/breadcrumb/setings.vue";
|
import Setings from "/@/views/layout/navBars/breadcrumb/setings.vue";
|
||||||
export default {
|
export default {
|
||||||
@ -37,7 +37,9 @@ export default {
|
|||||||
// 设置初始化,防止刷新时恢复默认
|
// 设置初始化,防止刷新时恢复默认
|
||||||
onBeforeMount(() => {
|
onBeforeMount(() => {
|
||||||
// 设置批量第三方 icon 图标
|
// 设置批量第三方 icon 图标
|
||||||
setIconfont();
|
setIntroduction.cssCdn();
|
||||||
|
// 设置批量第三方 js
|
||||||
|
setIntroduction.jsCdn();
|
||||||
});
|
});
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { computed } from "vue";
|
import { computed } from "vue";
|
||||||
import { useStore } from "/@/store/index.ts";
|
import { useStore } from "/@/store/index.ts";
|
||||||
|
import { judementSameArr } from "/@/utils/arrayOperation.ts";
|
||||||
export default {
|
export default {
|
||||||
nane: "authAll",
|
nane: "authAll",
|
||||||
props: {
|
props: {
|
||||||
@ -17,17 +18,6 @@ export default {
|
|||||||
},
|
},
|
||||||
setup(props) {
|
setup(props) {
|
||||||
const store = useStore();
|
const store = useStore();
|
||||||
// 判断两数组是否相同
|
|
||||||
const judementSameArr = (news, old) => {
|
|
||||||
let count = 0;
|
|
||||||
const leng = old.length;
|
|
||||||
for (let i in old) {
|
|
||||||
for (let j in news) {
|
|
||||||
if (old[i] === news[j]) count++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return count === leng ? true : false;
|
|
||||||
};
|
|
||||||
// 获取 vuex 中的用户权限
|
// 获取 vuex 中的用户权限
|
||||||
const getUserAuthBtnList = computed(() => {
|
const getUserAuthBtnList = computed(() => {
|
||||||
return judementSameArr(props.value, store.state.userInfos.authBtnList);
|
return judementSameArr(props.value, store.state.userInfos.authBtnList);
|
||||||
|
@ -168,7 +168,7 @@ body,
|
|||||||
|
|
||||||
/* 外边距、内边距全局样式
|
/* 外边距、内边距全局样式
|
||||||
------------------------------- */
|
------------------------------- */
|
||||||
@for $i from 1 through 30 {
|
@for $i from 1 through 35 {
|
||||||
.mt#{$i} {
|
.mt#{$i} {
|
||||||
margin-top: #{$i}px !important;
|
margin-top: #{$i}px !important;
|
||||||
}
|
}
|
||||||
|
@ -821,6 +821,9 @@
|
|||||||
.el-tabs__active-bar {
|
.el-tabs__active-bar {
|
||||||
background-color: set-color(primary);
|
background-color: set-color(primary);
|
||||||
}
|
}
|
||||||
|
.el-tabs__nav-wrap::after {
|
||||||
|
height: 1px !important;
|
||||||
|
}
|
||||||
|
|
||||||
/* Breadcrumb 面包屑
|
/* Breadcrumb 面包屑
|
||||||
------------------------------- */
|
------------------------------- */
|
||||||
@ -877,6 +880,12 @@
|
|||||||
color: set-color(primary);
|
color: set-color(primary);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Card 卡片
|
||||||
|
------------------------------- */
|
||||||
|
.el-card__header {
|
||||||
|
padding: 15px 20px;
|
||||||
|
}
|
||||||
|
|
||||||
/* Timeline 时间线
|
/* Timeline 时间线
|
||||||
------------------------------- */
|
------------------------------- */
|
||||||
// primary
|
// primary
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
@import './index.scss';
|
|
||||||
|
|
||||||
/* 页面宽度小于576px
|
|
||||||
------------------------------- */
|
|
||||||
@media screen and (max-width: $xs) {
|
|
||||||
// tagsView 操作
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 页面宽度小于768px
|
|
||||||
------------------------------- */
|
|
||||||
@media screen and (max-width: $sm) {
|
|
||||||
// tagsView 操作
|
|
||||||
}
|
|
@ -2,4 +2,4 @@
|
|||||||
@import './error.scss';
|
@import './error.scss';
|
||||||
@import './layout.scss';
|
@import './layout.scss';
|
||||||
@import './form.scss';
|
@import './form.scss';
|
||||||
@import './examples.scss';
|
@import './personal.scss';
|
||||||
|
16
vue-admin-wonderful-next/src/theme/media/personal.scss
Normal file
16
vue-admin-wonderful-next/src/theme/media/personal.scss
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
@import './index.scss';
|
||||||
|
|
||||||
|
/* 页面宽度小于768px
|
||||||
|
------------------------------- */
|
||||||
|
@media screen and (max-width: $sm) {
|
||||||
|
.personal-info {
|
||||||
|
padding-left: 0 !important;
|
||||||
|
margin-top: 15px;
|
||||||
|
}
|
||||||
|
.personal-recommend-col {
|
||||||
|
margin-bottom: 15px;
|
||||||
|
&:last-of-type {
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
11
vue-admin-wonderful-next/src/utils/arrayOperation.ts
Normal file
11
vue-admin-wonderful-next/src/utils/arrayOperation.ts
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
// 判断两数组是否相同
|
||||||
|
export function judementSameArr(news: Array<string>, old: Array<string>) {
|
||||||
|
let count = 0
|
||||||
|
const leng = old.length
|
||||||
|
for (let i in old) {
|
||||||
|
for (let j in news) {
|
||||||
|
if (old[i] === news[j]) count++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return count === leng ? true : false
|
||||||
|
}
|
@ -1,17 +1,6 @@
|
|||||||
import type { App } from 'vue'
|
import type { App } from 'vue'
|
||||||
import { store } from "/@/store/index.ts";
|
import { store } from "/@/store/index.ts";
|
||||||
|
import { judementSameArr } from '/@/utils/arrayOperation.ts'
|
||||||
// 判断两数组是否相同
|
|
||||||
export function judementSameArr(news: Array<string>, old: Array<string>) {
|
|
||||||
let count = 0
|
|
||||||
const leng = old.length
|
|
||||||
for (let i in old) {
|
|
||||||
for (let j in news) {
|
|
||||||
if (old[i] === news[j]) count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return count === leng ? true : false
|
|
||||||
}
|
|
||||||
|
|
||||||
export function authDirective(app: App) {
|
export function authDirective(app: App) {
|
||||||
// 单个权限验证(v-auth="xxx")
|
// 单个权限验证(v-auth="xxx")
|
||||||
|
@ -1,16 +1,5 @@
|
|||||||
import { store } from "/@/store/index.ts";
|
import { store } from "/@/store/index.ts";
|
||||||
|
import { judementSameArr } from '/@/utils/arrayOperation.ts'
|
||||||
// 判断两数组是否相同
|
|
||||||
export function judementSameArr(news: Array<string>, old: Array<string>) {
|
|
||||||
let count = 0
|
|
||||||
const leng = old.length
|
|
||||||
for (let i in old) {
|
|
||||||
for (let j in news) {
|
|
||||||
if (old[i] === news[j]) count++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return count === leng ? true : false
|
|
||||||
}
|
|
||||||
|
|
||||||
// 单个权限验证
|
// 单个权限验证
|
||||||
export function auth(value: string) {
|
export function auth(value: string) {
|
||||||
|
@ -1,13 +1,38 @@
|
|||||||
// 字体图标 url
|
// 字体图标 url
|
||||||
const urlArr = ["//at.alicdn.com/t/font_2298093_anmim41evr5.css"]
|
const cssCdnUrlList: Array<string> = ["//at.alicdn.com/t/font_2298093_anmim41evr5.css"]
|
||||||
|
// 第三方 js url
|
||||||
|
const jsCdnUrlList: Array<string> = []
|
||||||
|
|
||||||
// 动态设置字体图标
|
// 动态设置字体图标
|
||||||
export function setIconfont() {
|
export function setCssCdn() {
|
||||||
if (urlArr.length <= 0) return false
|
if (cssCdnUrlList.length <= 0) return false
|
||||||
urlArr.map(v => {
|
cssCdnUrlList.map(v => {
|
||||||
let link = document.createElement('link')
|
let link = document.createElement('link')
|
||||||
link.rel = 'stylesheet'
|
link.rel = 'stylesheet'
|
||||||
link.href = v
|
link.href = v
|
||||||
document.getElementsByTagName('head')[0].appendChild(link)
|
document.getElementsByTagName('head')[0].appendChild(link)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 批量设置第三方js
|
||||||
|
export function setJsCdn() {
|
||||||
|
if (jsCdnUrlList.length <= 0) return false
|
||||||
|
jsCdnUrlList.map(v => {
|
||||||
|
let link = document.createElement('script')
|
||||||
|
link.src = v
|
||||||
|
document.body.appendChild(link)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// 设置执行函数
|
||||||
|
const setIntroduction = {
|
||||||
|
cssCdn: () => {
|
||||||
|
setCssCdn()
|
||||||
|
},
|
||||||
|
jsCdn: () => {
|
||||||
|
setJsCdn()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 导出函数方法
|
||||||
|
export default setIntroduction
|
@ -3,11 +3,12 @@
|
|||||||
<Header />
|
<Header />
|
||||||
<el-container class="layout-mian-height-50">
|
<el-container class="layout-mian-height-50">
|
||||||
<Aside />
|
<Aside />
|
||||||
<div class="flex-center">
|
<div class="flex-center layout-backtop">
|
||||||
<TagsView />
|
<TagsView />
|
||||||
<Main />
|
<Main />
|
||||||
</div>
|
</div>
|
||||||
</el-container>
|
</el-container>
|
||||||
|
<el-backtop target=".layout-backtop .el-main .el-scrollbar__wrap"></el-backtop>
|
||||||
</el-container>
|
</el-container>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<ColumnsAside />
|
<ColumnsAside />
|
||||||
<div class="layout-columns-warp">
|
<div class="layout-columns-warp">
|
||||||
<Aside />
|
<Aside />
|
||||||
<el-container class="flex-center">
|
<el-container class="flex-center layout-backtop">
|
||||||
<Header v-if="isFixedHeader" />
|
<Header v-if="isFixedHeader" />
|
||||||
<el-scrollbar>
|
<el-scrollbar>
|
||||||
<Header v-if="!isFixedHeader" />
|
<Header v-if="!isFixedHeader" />
|
||||||
@ -11,6 +11,7 @@
|
|||||||
</el-scrollbar>
|
</el-scrollbar>
|
||||||
</el-container>
|
</el-container>
|
||||||
</div>
|
</div>
|
||||||
|
<el-backtop target=".layout-backtop .el-scrollbar__wrap"></el-backtop>
|
||||||
</el-container>
|
</el-container>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
@ -1,13 +1,14 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-container class="layout-container">
|
<el-container class="layout-container">
|
||||||
<Aside />
|
<Aside />
|
||||||
<el-container class="flex-center">
|
<el-container class="flex-center layout-backtop">
|
||||||
<Header v-if="isFixedHeader" />
|
<Header v-if="isFixedHeader" />
|
||||||
<el-scrollbar>
|
<el-scrollbar>
|
||||||
<Header v-if="!isFixedHeader" />
|
<Header v-if="!isFixedHeader" />
|
||||||
<Main />
|
<Main />
|
||||||
</el-scrollbar>
|
</el-scrollbar>
|
||||||
</el-container>
|
</el-container>
|
||||||
|
<el-backtop target=".layout-backtop .el-scrollbar__wrap"></el-backtop>
|
||||||
</el-container>
|
</el-container>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-container class="layout-container flex-center">
|
<el-container class="layout-container flex-center layout-backtop">
|
||||||
<Header />
|
<Header />
|
||||||
<Main />
|
<Main />
|
||||||
|
<el-backtop target=".layout-backtop .el-main .el-scrollbar__wrap"></el-backtop>
|
||||||
</el-container>
|
</el-container>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
@ -255,7 +255,7 @@
|
|||||||
</el-select>
|
</el-select>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="layout-breadcrumb-seting-bar-flex mt15 mb27">
|
<div class="layout-breadcrumb-seting-bar-flex mt15 mb28">
|
||||||
<div class="layout-breadcrumb-seting-bar-flex-label">分栏高亮风格</div>
|
<div class="layout-breadcrumb-seting-bar-flex-label">分栏高亮风格</div>
|
||||||
<div class="layout-breadcrumb-seting-bar-flex-value">
|
<div class="layout-breadcrumb-seting-bar-flex-value">
|
||||||
<el-select v-model="getThemeConfig.columnsAsideStyle" placeholder="请选择" size="mini" style="width:90px;"
|
<el-select v-model="getThemeConfig.columnsAsideStyle" placeholder="请选择" size="mini" style="width:90px;"
|
||||||
|
@ -1,17 +1,203 @@
|
|||||||
<template>
|
<template>
|
||||||
<div>
|
<div class="personal">
|
||||||
personalIndex
|
<el-row>
|
||||||
<el-input v-model="val"></el-input>
|
<!-- 个人信息 -->
|
||||||
|
<el-col :xs="24" :sm="16">
|
||||||
|
<el-card shadow="hover" header="个人信息">
|
||||||
|
<div class="personal-user">
|
||||||
|
<div class="personal-user-left">
|
||||||
|
<el-upload class="h100 personal-user-left-upload" action="https://jsonplaceholder.typicode.com/posts/"
|
||||||
|
multiple :limit="1">
|
||||||
|
<img
|
||||||
|
src="https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=1813762643,1914315241&fm=26&gp=0.jpg" />
|
||||||
|
</el-upload>
|
||||||
|
</div>
|
||||||
|
<div class="personal-user-right">
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="24" class="personal-title mb18">傍晚好,admin,生活变的再糟糕,也不妨碍我变得更好!
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-row>
|
||||||
|
<el-col :xs="24" :sm="8" class="personal-item mb6">
|
||||||
|
<div class="personal-item-label">昵称:</div>
|
||||||
|
<div class="personal-item-value">小柒</div>
|
||||||
|
</el-col>
|
||||||
|
<el-col :xs="24" :sm="16" class="personal-item mb6">
|
||||||
|
<div class="personal-item-label">身份:</div>
|
||||||
|
<div class="personal-item-value">超级管理</div>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-row>
|
||||||
|
<el-col :xs="24" :sm="8" class="personal-item mb6">
|
||||||
|
<div class="personal-item-label">登录IP:</div>
|
||||||
|
<div class="personal-item-value">192.168.1.1</div>
|
||||||
|
</el-col>
|
||||||
|
<el-col :xs="24" :sm="16" class="personal-item mb6">
|
||||||
|
<div class="personal-item-label">登录时间:</div>
|
||||||
|
<div class="personal-item-value">2021-02-05 18:47:26</div>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-card>
|
||||||
|
</el-col>
|
||||||
|
|
||||||
|
<!-- 消息通知 -->
|
||||||
|
<el-col :xs="24" :sm="8" class="pl15 personal-info">
|
||||||
|
<el-card shadow="hover">
|
||||||
|
<template #header>
|
||||||
|
<span>消息通知</span>
|
||||||
|
<span class="personal-info-more">更多</span>
|
||||||
|
</template>
|
||||||
|
<div class="personal-info-box">
|
||||||
|
<ul class="personal-info-ul">
|
||||||
|
<li v-for="(v,k) in newsInfoList" :key="k" class="personal-info-li">
|
||||||
|
<a href="#" class="personal-info-li-title">{{v.title}}</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</el-card>
|
||||||
|
</el-col>
|
||||||
|
|
||||||
|
<!-- 营销推荐 -->
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-card shadow="hover" class="mt15" header="营销推荐">
|
||||||
|
<el-row :gutter="15" class="personal-recommend-row">
|
||||||
|
<el-col :sm="6" v-for="(v,k) in recommendList" :key="k" class="personal-recommend-col">
|
||||||
|
<div class="personal-recommend" :style="{'background-color': v.bg}">
|
||||||
|
<i :class="v.icon" :style="{'color': v.iconColor}"></i>
|
||||||
|
<div class="personal-recommend-auto">
|
||||||
|
<div>{{v.title}}</div>
|
||||||
|
<div class="personal-recommend-msg">{{v.msg}}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-card>
|
||||||
|
</el-col>
|
||||||
|
|
||||||
|
<!-- 更新信息 -->
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-card shadow="hover" class="mt15 personal-edit" header="更新信息">
|
||||||
|
<div class="personal-edit-title">基本信息</div>
|
||||||
|
<el-form :model="personalForm" size="small" label-width="40px" class="personal-edit-form mt35 mb35">
|
||||||
|
<el-row :gutter="35">
|
||||||
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
|
<el-form-item label="昵称">
|
||||||
|
<el-input v-model="personalForm.name" placeholder="请输入昵称" clearable></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
|
<el-form-item label="邮箱">
|
||||||
|
<el-input v-model="personalForm.email" placeholder="请输入邮箱" clearable></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
|
<el-form-item label="签名">
|
||||||
|
<el-input v-model="personalForm.autograph" placeholder="请输入签名" clearable></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
|
<el-form-item label="职业">
|
||||||
|
<el-select v-model="personalForm.occupation" placeholder="请选择职业" clearable class="w100">
|
||||||
|
<el-option label="计算机 / 互联网 / 通信" value="1"></el-option>
|
||||||
|
<el-option label="生产 / 工艺 / 制造" value="2"></el-option>
|
||||||
|
<el-option label="医疗 / 护理 / 制药" value="3"></el-option>
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
|
<el-form-item label="手机">
|
||||||
|
<el-input v-model="personalForm.phone" placeholder="请输入手机" clearable></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
|
<el-form-item label="性别">
|
||||||
|
<el-select v-model="personalForm.sex" placeholder="请选择性别" clearable class="w100">
|
||||||
|
<el-option label="男" value="1"></el-option>
|
||||||
|
<el-option label="女" value="2"></el-option>
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
|
||||||
|
<el-form-item>
|
||||||
|
<el-button type="primary">更新个人信息</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-form>
|
||||||
|
<div class="personal-edit-title mb15">账号安全</div>
|
||||||
|
<div class="personal-edit-safe-box">
|
||||||
|
<div class="personal-edit-safe-item">
|
||||||
|
<div class="personal-edit-safe-item-left">
|
||||||
|
<div class="personal-edit-safe-item-left-label">账户密码</div>
|
||||||
|
<div class="personal-edit-safe-item-left-value">当前密码强度:强</div>
|
||||||
|
</div>
|
||||||
|
<div class="personal-edit-safe-item-right">
|
||||||
|
<el-button type="text">立即修改</el-button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="personal-edit-safe-box">
|
||||||
|
<div class="personal-edit-safe-item">
|
||||||
|
<div class="personal-edit-safe-item-left">
|
||||||
|
<div class="personal-edit-safe-item-left-label">密保手机</div>
|
||||||
|
<div class="personal-edit-safe-item-left-value">已绑定手机:132****4108</div>
|
||||||
|
</div>
|
||||||
|
<div class="personal-edit-safe-item-right">
|
||||||
|
<el-button type="text">立即修改</el-button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="personal-edit-safe-box">
|
||||||
|
<div class="personal-edit-safe-item">
|
||||||
|
<div class="personal-edit-safe-item-left">
|
||||||
|
<div class="personal-edit-safe-item-left-label">密保问题</div>
|
||||||
|
<div class="personal-edit-safe-item-left-value">已设置密保问题,账号安全大幅度提升</div>
|
||||||
|
</div>
|
||||||
|
<div class="personal-edit-safe-item-right">
|
||||||
|
<el-button type="text">立即设置</el-button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="personal-edit-safe-box">
|
||||||
|
<div class="personal-edit-safe-item">
|
||||||
|
<div class="personal-edit-safe-item-left">
|
||||||
|
<div class="personal-edit-safe-item-left-label">绑定QQ</div>
|
||||||
|
<div class="personal-edit-safe-item-left-value">已绑定QQ:110****566</div>
|
||||||
|
</div>
|
||||||
|
<div class="personal-edit-safe-item-right">
|
||||||
|
<el-button type="text">立即设置</el-button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</el-card>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { toRefs, reactive } from "vue";
|
import { toRefs, reactive, computed } from "vue";
|
||||||
|
import { newsInfoList, recommendList } from "./mock.ts";
|
||||||
export default {
|
export default {
|
||||||
name: "personal",
|
name: "personal",
|
||||||
setup() {
|
setup() {
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
val: "",
|
newsInfoList,
|
||||||
|
recommendList,
|
||||||
|
personalForm: {
|
||||||
|
name: "",
|
||||||
|
email: "",
|
||||||
|
autograph: "",
|
||||||
|
occupation: "",
|
||||||
|
phone: "",
|
||||||
|
sex: "",
|
||||||
|
},
|
||||||
});
|
});
|
||||||
return {
|
return {
|
||||||
...toRefs(state),
|
...toRefs(state),
|
||||||
@ -19,3 +205,167 @@ export default {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
@import "../../theme/mixins/mixins.scss";
|
||||||
|
.personal {
|
||||||
|
.personal-user {
|
||||||
|
height: 130px;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
.personal-user-left {
|
||||||
|
width: 100px;
|
||||||
|
height: 130px;
|
||||||
|
border-radius: 3px;
|
||||||
|
::v-deep(.el-upload) {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
.personal-user-left-upload {
|
||||||
|
img {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
border-radius: 3px;
|
||||||
|
}
|
||||||
|
&:hover {
|
||||||
|
img {
|
||||||
|
animation: logoAnimation 0.3s ease-in-out;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.personal-user-right {
|
||||||
|
flex: 1;
|
||||||
|
padding: 0 15px;
|
||||||
|
.personal-title {
|
||||||
|
font-size: 18px;
|
||||||
|
@include text-ellipsis(1);
|
||||||
|
}
|
||||||
|
.personal-item {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
font-size: 13px;
|
||||||
|
.personal-item-label {
|
||||||
|
color: gray;
|
||||||
|
@include text-ellipsis(1);
|
||||||
|
}
|
||||||
|
.personal-item-value {
|
||||||
|
@include text-ellipsis(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.personal-info {
|
||||||
|
.personal-info-more {
|
||||||
|
float: right;
|
||||||
|
color: gray;
|
||||||
|
font-size: 13px;
|
||||||
|
&:hover {
|
||||||
|
color: var(--color-primary);
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.personal-info-box {
|
||||||
|
height: 130px;
|
||||||
|
overflow: hidden;
|
||||||
|
.personal-info-ul {
|
||||||
|
list-style: none;
|
||||||
|
.personal-info-li {
|
||||||
|
font-size: 13px;
|
||||||
|
padding-bottom: 10px;
|
||||||
|
.personal-info-li-title {
|
||||||
|
display: inline-block;
|
||||||
|
@include text-ellipsis(1);
|
||||||
|
color: grey;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
& a:hover {
|
||||||
|
color: var(--color-primary);
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.personal-recommend-row {
|
||||||
|
.personal-recommend-col {
|
||||||
|
.personal-recommend {
|
||||||
|
position: relative;
|
||||||
|
height: 100px;
|
||||||
|
color: #ffffff;
|
||||||
|
border-radius: 3px;
|
||||||
|
overflow: hidden;
|
||||||
|
cursor: pointer;
|
||||||
|
&:hover {
|
||||||
|
i {
|
||||||
|
right: 0px !important;
|
||||||
|
bottom: 0px !important;
|
||||||
|
transition: all ease 0.3s;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
i {
|
||||||
|
position: absolute;
|
||||||
|
right: -10px;
|
||||||
|
bottom: -10px;
|
||||||
|
font-size: 70px;
|
||||||
|
transform: rotate(-30deg);
|
||||||
|
transition: all ease 0.3s;
|
||||||
|
}
|
||||||
|
.personal-recommend-auto {
|
||||||
|
padding: 15px;
|
||||||
|
position: absolute;
|
||||||
|
left: 0;
|
||||||
|
top: 5%;
|
||||||
|
.personal-recommend-msg {
|
||||||
|
font-size: 12px;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.personal-edit {
|
||||||
|
.personal-edit-title {
|
||||||
|
position: relative;
|
||||||
|
padding-left: 10px;
|
||||||
|
color: #606266;
|
||||||
|
&::after {
|
||||||
|
content: "";
|
||||||
|
width: 2px;
|
||||||
|
height: 10px;
|
||||||
|
position: absolute;
|
||||||
|
left: 0;
|
||||||
|
top: 50%;
|
||||||
|
transform: translateY(-50%);
|
||||||
|
background: var(--color-primary);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.personal-edit-safe-box {
|
||||||
|
border-bottom: 1px solid #ebeef5;
|
||||||
|
padding: 15px 0;
|
||||||
|
.personal-edit-safe-item {
|
||||||
|
width: 100%;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: space-between;
|
||||||
|
.personal-edit-safe-item-left {
|
||||||
|
flex: 1;
|
||||||
|
overflow: hidden;
|
||||||
|
.personal-edit-safe-item-left-label {
|
||||||
|
color: #606266;
|
||||||
|
margin-bottom: 5px;
|
||||||
|
}
|
||||||
|
.personal-edit-safe-item-left-value {
|
||||||
|
color: gray;
|
||||||
|
@include text-ellipsis(1);
|
||||||
|
margin-right: 15px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
&:last-of-type {
|
||||||
|
padding-bottom: 0;
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
64
vue-admin-wonderful-next/src/views/personal/mock.ts
Normal file
64
vue-admin-wonderful-next/src/views/personal/mock.ts
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
// 消息通知
|
||||||
|
export const newsInfoList: Array<object> = [
|
||||||
|
{
|
||||||
|
title: "[发布] 2020年11月15日发布 v1.0.0 版本",
|
||||||
|
date: "11/15",
|
||||||
|
link: "https://gitee.com/lyt-top/vue-admin-wonderful",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title:
|
||||||
|
"[预览] pro 版本预览 http://lyt-top.gitee.io/vue-admin-wonderful-preview",
|
||||||
|
date: "11/15",
|
||||||
|
link: "http://lyt-top.gitee.io/vue-admin-wonderful-preview",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title:
|
||||||
|
"[预览] fashion 版本预览 http://lyt-top.gitee.io/vue-admin-wonderful-fashion-preview",
|
||||||
|
date: "11/15",
|
||||||
|
link: "http://lyt-top.gitee.io/vue-admin-wonderful-fashion-preview",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title:
|
||||||
|
"[预览] classic 版本预览 http://lyt-top.gitee.io/vue-admin-wonderful-classic-preview",
|
||||||
|
date: "11/15",
|
||||||
|
link: "http://lyt-top.gitee.io/vue-admin-wonderful-classic-preview",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title:
|
||||||
|
"[预览] elegant 版本预览 http://lyt-top.gitee.io/vue-admin-wonderful-elegant-preview",
|
||||||
|
date: "11/15",
|
||||||
|
link: "http://lyt-top.gitee.io/vue-admin-wonderful-elegant-preview",
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
// 营销推荐
|
||||||
|
export const recommendList: Array<object> = [
|
||||||
|
{
|
||||||
|
title: "优惠券",
|
||||||
|
msg: "现金券、折扣券、营销必备",
|
||||||
|
icon: "el-icon-food",
|
||||||
|
bg: "#48D18D",
|
||||||
|
iconColor: "#64d89d",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: "多人拼团",
|
||||||
|
msg: "社交电商、开辟流量",
|
||||||
|
icon: "el-icon-shopping-bag-1",
|
||||||
|
bg: "#F95959",
|
||||||
|
iconColor: "#F86C6B",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: "分销中心",
|
||||||
|
msg: "轻松招募分销员,成功推广奖励",
|
||||||
|
icon: "el-icon-school",
|
||||||
|
bg: "#8595F4",
|
||||||
|
iconColor: "#92A1F4",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: "秒杀",
|
||||||
|
msg: "超低价抢购引导更多销量",
|
||||||
|
icon: "el-icon-alarm-clock",
|
||||||
|
bg: "#FEBB50",
|
||||||
|
iconColor: "#FDC566",
|
||||||
|
},
|
||||||
|
]
|
@ -1,21 +1,484 @@
|
|||||||
<template>
|
<template>
|
||||||
|
<el-card shadow="hover" header="正则验证(一些项目中常用的正则)">
|
||||||
|
<el-form :model="ruleForm" :rules="rules" class="tools-warp-form" size="small">
|
||||||
|
<el-form-item label="小数或整数:" prop="a1">
|
||||||
|
<div class="tools-warp-form-msg">验证可以输入小数或整数,0 开始, . 只能出现一次,保留小数点后保留2位小数。(负数时,模拟拼接负号给后台)。</div>
|
||||||
<div>
|
<div>
|
||||||
tools
|
<el-input v-model="ruleForm.a1" @input="onVerifyNumberIntegerAndFloat($event)" placeholder="请输入小数或整数进行测试">
|
||||||
<el-input v-model="val"></el-input>
|
</el-input>
|
||||||
</div>
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="正整数:" prop="a2" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证只可以输入正整数,0 开始后面将不可以输入。</div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a2" @input="onVerifiyNumberInteger($event)" placeholder="请输入整数进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="去掉中文及空格:" prop="a3" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证不可以输入空格与中文。</div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a3" @input="onVerifyCnAndSpace($event)" placeholder="请输入内容进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="去掉英文及空格:" prop="a4" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证不可以输入空格与英文。</div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a4" @input="onVerifyEnAndSpace($event)" placeholder="请输入内容进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="禁止输入空格:" prop="a5" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证不可以输入空格。</div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a5" @input="onVerifyAndSpace($event)" placeholder="请输入内容进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="金额用 `,` 区分开:" prop="a6" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">金额添加 `,` 进行区分,便于阅读。{{ruleForm.a6}}</div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a6" @input="onVerifyNumberComma($event)" placeholder="请输入金额进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="匹配文字变色(搜索时):" prop="a7" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">示例:<span v-html="text"></span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a7" @input="onVerifyTextColor($event)" placeholder="请输入示例中的部分文字">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="数字转中文大写:" prop="a8" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证数字转成中文的大写。<span class="tools-warp-form-msg-red">{{cnText}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a8" @input="onVerifyNumberCnUppercase($event)" placeholder="请输入金额进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="手机号码:" prop="a9" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证手机号码 (true: 正确,false: 不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{phone}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a9" @input="onVerifyPhone($event)" placeholder="请输入手机号进行测试" maxlength="11">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="国内电话号码:" prop="a10" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证国内电话号码 (true: 正确,false: 不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{telePhone}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a10" @input="onVerifyTelPhone($event)" placeholder="请输入国内电话号码进行测试" maxlength="12">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="登录账号:" prop="a11" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证登录账号是否正确。字母开头,允许5-16字节,允许字母数字下划线 (true: 正确,false: 不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{account}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a11" @input="onVerifyAccount($event)" placeholder="请输入账号进行测试" maxlength="16">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="密码:" prop="a12" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证密码是否正确。以字母开头,长度在6~16之间,只能包含字母、数字和下划线 (true: 正确,false: 不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{password}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a12" @input="onVerifyPassword($event)" placeholder="请输入密码进行测试" maxlength="16">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="强密码:" prop="a13" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证强密码是否正确。字母+数字+特殊字符,长度在6-16之间 (true: 正确,false:
|
||||||
|
不正确)。<span class="tools-warp-form-msg-red">{{passwordPowerful}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a13" @input="onVerifyPasswordPowerful($event)" placeholder="请输入密码进行测试"
|
||||||
|
maxlength="16">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="密码强度:" prop="a14" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证密码强度。返回 强、中、弱。(弱:纯数字,纯字母,纯特殊字符,中:字母+数字,字母+特殊字符,数字+特殊字符,强:字母+数字+特殊字符)<span
|
||||||
|
class="tools-warp-form-msg-red">{{passwordStrength}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a14" @input="onVerifyPasswordStrength($event)" placeholder="请输入密码进行测试"
|
||||||
|
maxlength="16">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="IP地址:" prop="a15" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证IP地址是否正确。(true: 正确,false: 不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{iPAddress}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a15" @input="onVerifyIPAddress($event)" placeholder="请输入IP地址进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="邮箱:" prop="a16" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证邮箱是否正确。(true: 正确,false:不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{email}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a16" @input="onVerifyEmail($event)" placeholder="请输入邮箱进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="身份证:" prop="a17" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证身份证是否正确。(true: 正确,false:不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{idCard}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a17" @input="onVerifyIDCard($event)" placeholder="请输入身份证进行测试" maxlength="18">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="姓名:" prop="a18" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证姓名是否正确,包括少数民族名字。(true: 正确,false:不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{fullName}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a18" @input="onVerifyFullName($event)" placeholder="请输入姓名进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="邮政编码:" prop="a19" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证邮政编码是否正确,不能以 0 开始。(true: 正确,false:不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{postalCode}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a19" @input="onVerifyPostalCode($event)" placeholder="请输入邮政编码进行测试" maxlength="6">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="url:" prop="a20" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证url是否正确。(true: 正确,false:不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{url}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a20" @input="onVerifyUrl($event)" placeholder="请输入内容进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="车牌号:" prop="a21" class="mt20">
|
||||||
|
<div class="tools-warp-form-msg">验证车牌号是否正确。(true: 正确,false:不正确)。<span
|
||||||
|
class="tools-warp-form-msg-red">{{carNum}}</span></div>
|
||||||
|
<div>
|
||||||
|
<el-input v-model="ruleForm.a21" @input="onVerifyCarNum($event)" placeholder="请输入车牌号进行测试">
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
</el-card>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { toRefs, reactive } from "vue";
|
import { reactive, toRefs } from "vue";
|
||||||
|
import {
|
||||||
|
verifyNumberIntegerAndFloat,
|
||||||
|
verifiyNumberInteger,
|
||||||
|
verifyCnAndSpace,
|
||||||
|
verifyEnAndSpace,
|
||||||
|
verifyAndSpace,
|
||||||
|
verifyNumberComma,
|
||||||
|
verifyTextColor,
|
||||||
|
verifyNumberCnUppercase,
|
||||||
|
verifyPhone,
|
||||||
|
verifyTelPhone,
|
||||||
|
verifyAccount,
|
||||||
|
verifyPassword,
|
||||||
|
verifyPasswordPowerful,
|
||||||
|
verifyPasswordStrength,
|
||||||
|
verifyIPAddress,
|
||||||
|
verifyEmail,
|
||||||
|
verifyIdCard,
|
||||||
|
verifyFullName,
|
||||||
|
verifyPostalCode,
|
||||||
|
verifyUrl,
|
||||||
|
verifyCarNum,
|
||||||
|
} from "/@/utils/toolsValidate.js";
|
||||||
export default {
|
export default {
|
||||||
name: "tools",
|
name: "tools",
|
||||||
setup() {
|
setup() {
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
val: "",
|
text: "世间美好,与你环环相扣,祝你开心每一天!",
|
||||||
|
phone: "",
|
||||||
|
cnText: "",
|
||||||
|
telePhone: "",
|
||||||
|
account: "",
|
||||||
|
password: "",
|
||||||
|
passwordPowerful: "",
|
||||||
|
passwordStrength: "",
|
||||||
|
iPAddress: "",
|
||||||
|
email: "",
|
||||||
|
idCard: "",
|
||||||
|
fullName: "",
|
||||||
|
postalCode: "",
|
||||||
|
url: "",
|
||||||
|
carNum: "",
|
||||||
|
/**
|
||||||
|
* 变量名为了方便,随便取了,
|
||||||
|
* 实际中,按正常程序进行命名
|
||||||
|
*/
|
||||||
|
ruleForm: {
|
||||||
|
a1: "",
|
||||||
|
a2: "",
|
||||||
|
a3: "",
|
||||||
|
a4: "",
|
||||||
|
a5: "",
|
||||||
|
a6: "",
|
||||||
|
a7: "",
|
||||||
|
a8: "",
|
||||||
|
a9: "",
|
||||||
|
a10: "",
|
||||||
|
a11: "",
|
||||||
|
a12: "",
|
||||||
|
a13: "",
|
||||||
|
a14: "",
|
||||||
|
a15: "",
|
||||||
|
a16: "",
|
||||||
|
a16: "",
|
||||||
|
a17: "",
|
||||||
|
a18: "",
|
||||||
|
a19: "",
|
||||||
|
a20: "",
|
||||||
|
a21: "",
|
||||||
|
},
|
||||||
|
rules: {
|
||||||
|
a1: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: "请输入小数或整数进行测试",
|
||||||
|
trigger: "change",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
a2: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: "请输入正整数进行测试",
|
||||||
|
trigger: "change",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
a3: [
|
||||||
|
{ required: true, message: "请输入内容进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a4: [
|
||||||
|
{ required: true, message: "请输入内容进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a5: [
|
||||||
|
{ required: true, message: "请输入内容进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a6: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: "请输入小数或整数进行测试",
|
||||||
|
trigger: "change",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
a7: [
|
||||||
|
{ required: true, message: "请输入内容进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a8: [
|
||||||
|
{ required: true, message: "请输入金额进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a9: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: "请输入手机号进行测试",
|
||||||
|
trigger: "change",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
a10: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: "请输入国内电话号码进行测试",
|
||||||
|
trigger: "change",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
a11: [
|
||||||
|
{ required: true, message: "请输入账号进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a12: [
|
||||||
|
{ required: true, message: "请输入密码进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a13: [
|
||||||
|
{ required: true, message: "请输入密码进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a14: [
|
||||||
|
{ required: true, message: "请输入密码进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a15: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: "请输入IP地址进行测试",
|
||||||
|
trigger: "change",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
a16: [
|
||||||
|
{ required: true, message: "请输入邮箱进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a17: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: "请输入身份证进行测试",
|
||||||
|
trigger: "change",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
a18: [
|
||||||
|
{ required: true, message: "请输入姓名进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a19: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: "请输入邮政编码进行测试",
|
||||||
|
trigger: "change",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
a20: [
|
||||||
|
{ required: true, message: "请输入内容进行测试", trigger: "change" },
|
||||||
|
],
|
||||||
|
a21: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: "请输入车牌号进行测试",
|
||||||
|
trigger: "change",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
// 小数或整数
|
||||||
|
const onVerifyNumberIntegerAndFloat = (val) => {
|
||||||
|
state.ruleForm.a1 = verifyNumberIntegerAndFloat(val);
|
||||||
|
};
|
||||||
|
// 正整数
|
||||||
|
const onVerifiyNumberInteger = (val) => {
|
||||||
|
state.ruleForm.a2 = verifiyNumberInteger(val);
|
||||||
|
};
|
||||||
|
// 去掉中文及空格
|
||||||
|
const onVerifyCnAndSpace = (val) => {
|
||||||
|
state.ruleForm.a3 = verifyCnAndSpace(val);
|
||||||
|
};
|
||||||
|
// 去掉英文及空格
|
||||||
|
const onVerifyEnAndSpace = (val) => {
|
||||||
|
state.ruleForm.a4 = verifyEnAndSpace(val);
|
||||||
|
};
|
||||||
|
// 禁止输入空格
|
||||||
|
const onVerifyAndSpace = (val) => {
|
||||||
|
state.ruleForm.a5 = verifyAndSpace(val);
|
||||||
|
};
|
||||||
|
// 金额用 `,` 区分开
|
||||||
|
const onVerifyNumberComma = (val) => {
|
||||||
|
state.ruleForm.a6 = verifyNumberComma(val);
|
||||||
|
};
|
||||||
|
// 匹配文字变色(搜索时)
|
||||||
|
const onVerifyTextColor = (val) => {
|
||||||
|
state.ruleForm.a7 = verifyAndSpace(val);
|
||||||
|
if (state.ruleForm.a7 === "")
|
||||||
|
state.text = `世间美好,与你环环相扣,祝你开心每一天!`;
|
||||||
|
else state.text = verifyTextColor(state.ruleForm.a7, state.text);
|
||||||
|
};
|
||||||
|
// 数字转中文大写
|
||||||
|
const onVerifyNumberCnUppercase = (val) => {
|
||||||
|
state.ruleForm.a8 = verifyNumberIntegerAndFloat(val);
|
||||||
|
if (state.ruleForm.a8 === "") state.cnText = "";
|
||||||
|
else state.cnText = verifyNumberCnUppercase(state.ruleForm.a8);
|
||||||
|
};
|
||||||
|
// 手机号码
|
||||||
|
const onVerifyPhone = (val) => {
|
||||||
|
state.phone = verifyPhone(val);
|
||||||
|
};
|
||||||
|
// 国内电话号码
|
||||||
|
const onVerifyTelPhone = (val) => {
|
||||||
|
state.telePhone = verifyTelPhone(val);
|
||||||
|
};
|
||||||
|
// 登录账号
|
||||||
|
const onVerifyAccount = (val) => {
|
||||||
|
state.ruleForm.a11 = verifyCnAndSpace(val);
|
||||||
|
state.account = verifyAccount(state.ruleForm.a11);
|
||||||
|
};
|
||||||
|
// 密码
|
||||||
|
const onVerifyPassword = (val) => {
|
||||||
|
state.ruleForm.a12 = verifyCnAndSpace(val);
|
||||||
|
state.password = verifyPassword(state.ruleForm.a12);
|
||||||
|
};
|
||||||
|
// 强密码
|
||||||
|
const onVerifyPasswordPowerful = (val) => {
|
||||||
|
state.ruleForm.a13 = verifyCnAndSpace(val);
|
||||||
|
state.passwordPowerful = verifyPasswordPowerful(state.ruleForm.a13);
|
||||||
|
};
|
||||||
|
// 密码强度
|
||||||
|
const onVerifyPasswordStrength = (val) => {
|
||||||
|
state.ruleForm.a14 = verifyCnAndSpace(val);
|
||||||
|
state.passwordStrength = verifyPasswordStrength(state.ruleForm.a14);
|
||||||
|
};
|
||||||
|
// IP地址
|
||||||
|
const onVerifyIPAddress = (val) => {
|
||||||
|
state.iPAddress = verifyIPAddress(val);
|
||||||
|
};
|
||||||
|
// 邮箱
|
||||||
|
const onVerifyEmail = (val) => {
|
||||||
|
state.ruleForm.a16 = verifyCnAndSpace(val);
|
||||||
|
state.email = verifyEmail(state.ruleForm.a16);
|
||||||
|
};
|
||||||
|
// 身份证
|
||||||
|
const onVerifyIDCard = (val) => {
|
||||||
|
state.ruleForm.a17 = verifyCnAndSpace(val);
|
||||||
|
state.idCard = verifyIdCard(state.ruleForm.a17);
|
||||||
|
};
|
||||||
|
// 姓名
|
||||||
|
const onVerifyFullName = (val) => {
|
||||||
|
state.ruleForm.a18 = verifyAndSpace(val);
|
||||||
|
state.fullName = verifyFullName(state.ruleForm.a18);
|
||||||
|
};
|
||||||
|
// 邮政编码
|
||||||
|
const onVerifyPostalCode = (val) => {
|
||||||
|
state.ruleForm.a19 = verifiyNumberInteger(val);
|
||||||
|
state.postalCode = verifyPostalCode(state.ruleForm.a19);
|
||||||
|
};
|
||||||
|
// url
|
||||||
|
const onVerifyUrl = (val) => {
|
||||||
|
state.ruleForm.a20 = verifyAndSpace(val);
|
||||||
|
state.url = verifyUrl(state.ruleForm.a20);
|
||||||
|
};
|
||||||
|
// 车牌号
|
||||||
|
const onVerifyCarNum = (val) => {
|
||||||
|
state.ruleForm.a21 = verifyAndSpace(val);
|
||||||
|
state.carNum = verifyCarNum(state.ruleForm.a21);
|
||||||
|
};
|
||||||
return {
|
return {
|
||||||
|
onVerifyNumberIntegerAndFloat,
|
||||||
|
onVerifiyNumberInteger,
|
||||||
|
onVerifyCnAndSpace,
|
||||||
|
onVerifyEnAndSpace,
|
||||||
|
onVerifyAndSpace,
|
||||||
|
onVerifyNumberComma,
|
||||||
|
onVerifyTextColor,
|
||||||
|
onVerifyNumberCnUppercase,
|
||||||
|
onVerifyPhone,
|
||||||
|
onVerifyTelPhone,
|
||||||
|
onVerifyAccount,
|
||||||
|
onVerifyPassword,
|
||||||
|
onVerifyPasswordPowerful,
|
||||||
|
onVerifyPasswordStrength,
|
||||||
|
onVerifyIPAddress,
|
||||||
|
onVerifyEmail,
|
||||||
|
onVerifyIDCard,
|
||||||
|
onVerifyFullName,
|
||||||
|
onVerifyPostalCode,
|
||||||
|
onVerifyUrl,
|
||||||
|
onVerifyCarNum,
|
||||||
...toRefs(state),
|
...toRefs(state),
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
.tools-warp-form {
|
||||||
|
::v-deep(.el-form-item--small.el-form-item) {
|
||||||
|
margin-bottom: 0 !important;
|
||||||
|
}
|
||||||
|
.tools-warp-form-msg {
|
||||||
|
color: #666666;
|
||||||
|
font-size: 14px;
|
||||||
|
.tools-warp-form-msg-red {
|
||||||
|
color: red;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
Loading…
Reference in New Issue
Block a user