vue实现登录拦截

作者:Jeslie-He 时间:2024-04-30 10:25:20 

本文实例为大家分享了vue实现登录拦截的具体代码,供大家参考,具体内容如下

需求:用户只有登录了,用户名存储在本地储存时,才能进入首页,如果本地存储没有用户名,就不能进入首页

1、登录页面的实现


<template>
<div class="htmleaf-container">
<div class="demo form-bg">
 <div class="container">
 <div class="row">
  <div class="col-md-offset-3 col-md-6">
  <form class="form-horizontal">
   <span class="heading">用户登录</span>
   <div class="form-group">
   <input type="text" class="form-control" id="inputtxt" placeholder="用户名" v-model="username" @blur="inputUserBlur" @focus="inputFocus">
   <i class="fa fa-user"></i>
   </div>
   <div class="form-group help">
   <input type="password" class="form-control" id="inputPassword3" placeholder="密码" v-model="psd" @blur="inputPsdBlur">
   <i class="fa fa-lock"></i>
   <a href="#" rel="external nofollow" class="fa fa-question-circle"></a>
   </div>
   <div class="form-group">
   <div class="main-checkbox">
    <input type="checkbox" value="None" id="checkbox1" name="check"/>
    <label for="checkbox1"></label>
   </div>
   <span class="text">记住我</span>
   <button type="button" class="btn btn-default" @click="loginBtn">立刻登录</button>
   </div>
  </form>
  </div>
 </div>
 </div>
</div>
</div>
</template>

<style lang="less" scoped>
@import 'http://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css';
@import 'http://cdn.bootcss.com/font-awesome/4.6.3/css/font-awesome.min.css';
@import '.././assets/login/css/index.css';
.form-bg{
padding: 2em 0;
}
.form-horizontal{
background: #fff;
padding-bottom: 40px;
border-radius: 15px;
text-align: center;
}
.form-horizontal .heading{
display: block;
font-size: 35px;
font-weight: 700;
padding: 35px 0;
border-bottom: 1px solid #f0f0f0;
margin-bottom: 30px;
}
.form-horizontal .form-group{
padding: 0 40px;
margin: 0 0 25px 0;
position: relative;
}
.form-horizontal .form-control{
background: #f0f0f0;
border: none;
border-radius: 20px;
box-shadow: none;
padding: 0 20px 0 45px;
height: 40px;
transition: all 0.3s ease 0s;
}
.form-horizontal .form-control:focus{
background: #e0e0e0;
box-shadow: none;
outline: 0 none;
}
.form-horizontal .form-group i{
position: absolute;
top: 12px;
left: 60px;
font-size: 17px;
color: #c8c8c8;
transition : all 0.5s ease 0s;
}
.form-horizontal .form-control:focus + i{
color: #00b4ef;
}
.form-horizontal .fa-question-circle{
display: inline-block;
position: absolute;
top: 12px;
right: 60px;
font-size: 20px;
color: #808080;
transition: all 0.5s ease 0s;
}
.form-horizontal .fa-question-circle:hover{
color: #000;
}
.form-horizontal .main-checkbox{
float: left;
width: 20px;
height: 20px;
background: #11a3fc;
border-radius: 50%;
position: relative;
margin: 5px 0 0 5px;
border: 1px solid #11a3fc;
}
.form-horizontal .main-checkbox label{
width: 20px;
height: 20px;
position: absolute;
top: 0;
left: 0;
cursor: pointer;
}
.form-horizontal .main-checkbox label:after{
content: "";
width: 10px;
height: 5px;
position: absolute;
top: 5px;
left: 4px;
border: 3px solid #fff;
border-top: none;
border-right: none;
background: transparent;
opacity: 0;
-webkit-transform: rotate(-45deg);
transform: rotate(-45deg);
}
.form-horizontal .main-checkbox input[type=checkbox]{
visibility: hidden;
}
.form-horizontal .main-checkbox input[type=checkbox]:checked + label:after{
opacity: 1;
}
.form-horizontal .text{
float: left;
margin-left: 7px;
line-height: 20px;
padding-top: 5px;
text-transform: capitalize;
}
.form-horizontal .btn{
float: right;
font-size: 14px;
color: #fff;
background: #00b4ef;
border-radius: 30px;
padding: 10px 25px;
border: none;
text-transform: capitalize;
transition: all 0.5s ease 0s;
}
@media only screen and (max-width: 479px){
.form-horizontal .form-group{
 padding: 0 25px;
}
.form-horizontal .form-group i{
 left: 45px;
}
.form-horizontal .btn{
 padding: 10px 20px;
}
}
</style>

index.css


/* @font-face {
font-family: 'icomoon';
src:url('../fonts/icomoon.eot?rretjt');
src:url('../fonts/icomoon.eot?#iefixrretjt') format('embedded-opentype'),
url('../fonts/icomoon.woff?rretjt') format('woff'),
url('../fonts/icomoon.ttf?rretjt') format('truetype'),
url('../fonts/icomoon.svg?rretjt#icomoon') format('svg');
font-weight: normal;
font-style: normal;
} */

[class^="icon-"], [class*=" icon-"] {
font-family: 'icomoon';
speak: none;
font-style: normal;
font-weight: normal;
font-variant: normal;
text-transform: none;
line-height: 1;

/* Better Font Rendering =========== */
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}

body, html { font-size: 100%; padding: 0; margin: 0;}

/* Reset */
*,
*:after,
*:before {
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
}

/* Clearfix hack by Nicolas Gallagher: http://nicolasgallagher.com/micro-clearfix-hack/ */
.clearfix:before,
.clearfix:after {
content: " ";
display: table;
}

.clearfix:after {
clear: both;
}

body{
background: #494A5F;
font-weight: 500;
font-size: 1.05em;
font-family: "Microsoft YaHei","Segoe UI", "Lucida Grande", Helvetica, Arial,sans-serif;
}
a{ color: rgba(255, 255, 255, 0.6);outline: none;text-decoration: none;-webkit-transition: 0.2s;transition: 0.2s;}
a:hover,a:focus{color:#74777b;text-decoration: none;}
.htmleaf-container{
margin: 0 auto;
}

.bgcolor-1 { background: #f0efee; }
.bgcolor-2 { background: #f9f9f9; }
.bgcolor-3 { background: #e8e8e8; }/*light grey*/
.bgcolor-4 { background: #2f3238; color: #fff; }/*Dark grey*/
.bgcolor-5 { background: #df6659; color: #521e18; }/*pink1*/
.bgcolor-6 { background: #2fa8ec; }/*sky blue*/
.bgcolor-7 { background: #d0d6d6; }/*White tea*/
.bgcolor-8 { background: #3d4444; color: #fff; }/*Dark grey2*/
.bgcolor-9 { background: #ef3f52; color: #fff;}/*pink2*/
.bgcolor-10{ background: #64448f; color: #fff;}/*Violet*/
.bgcolor-11{ background: #3755ad; color: #fff;}/*dark blue*/
.bgcolor-12{ background: #3498DB; color: #fff;}/*light blue*/
.bgcolor-20{ background: #494A5F;color: #D5D6E2;}
/* Header */
.htmleaf-header{
padding: 1em 190px 1em;
letter-spacing: -1px;
text-align: center;
background: #66677c;
}
.htmleaf-header h1 {
color: #D5D6E2;
font-weight: 600;
font-size: 2em;
line-height: 1;
margin-bottom: 0;
}
.htmleaf-header h1 span {
display: block;
font-size: 60%;
font-weight: 400;
padding: 0.8em 0 0.5em 0;
color: #c3c8cd;
}
/*nav*/
.htmleaf-demo a{color: #fff;text-decoration: none;}
.htmleaf-demo{width: 100%;padding-bottom: 1.2em;}
.htmleaf-demo a{display: inline-block;margin: 0.5em;padding: 0.6em 1em;border: 3px solid #fff;font-weight: 700;}
.htmleaf-demo a:hover{opacity: 0.6;}
.htmleaf-demo a.current{background:#1d7db1;color: #fff; }
/* Top Navigation Style */
.htmleaf-links {
position: relative;
display: inline-block;
white-space: nowrap;
font-size: 1.5em;
text-align: center;
}

.htmleaf-links::after {
position: absolute;
top: 0;
left: 50%;
margin-left: -1px;
width: 2px;
height: 100%;
background: #dbdbdb;
content: '';
-webkit-transform: rotate3d(0,0,1,22.5deg);
transform: rotate3d(0,0,1,22.5deg);
}

.htmleaf-icon {
display: inline-block;
margin: 0.5em;
padding: 0em 0;
width: 1.5em;
text-decoration: none;
}

.htmleaf-icon span {
display: none;
}

.htmleaf-icon:before {
margin: 0 5px;
text-transform: none;
font-weight: normal;
font-style: normal;
font-variant: normal;
font-family: 'icomoon';
line-height: 1;
speak: none;
-webkit-font-smoothing: antialiased;
}
/* footer */
.htmleaf-footer{width: 100%;padding-top: 10px;}
.htmleaf-small{font-size: 0.8em;}
.center{text-align: center;}
/****/
.related {
color: #fff;
background: #494A5F;
text-align: center;
font-size: 1.25em;
padding: 0.5em 0;
overflow: hidden;
}

.related > a {
vertical-align: top;
width: calc(100% - 20px);
max-width: 340px;
display: inline-block;
text-align: center;
margin: 20px 10px;
padding: 25px;
font-family: "Microsoft YaHei","宋体","Segoe UI", "Lucida Grande", Helvetica, Arial,sans-serif, FreeSans, Arimo;
}
.related a {
display: inline-block;
text-align: left;
margin: 20px auto;
padding: 10px 20px;
opacity: 0.8;
-webkit-transition: opacity 0.3s;
transition: opacity 0.3s;
-webkit-backface-visibility: hidden;
}

.related a:hover,
.related a:active {
opacity: 1;
}

.related a img {
max-width: 100%;
opacity: 0.8;
border-radius: 4px;
}
.related a:hover img,
.related a:active img {
opacity: 1;
}
.related h3{font-family: "Microsoft YaHei", sans-serif;font-size: 1.2em}
.related a h3 {
font-size: 0.85em;
font-weight: 300;
margin-top: 0.15em;
color: #fff;
}
/* icomoon */
.icon-htmleaf-home-outline:before {
content: "\e5000";
}

.icon-htmleaf-arrow-forward-outline:before {
content: "\e5001";
}

@media screen and (max-width: 1024px) {
.htmleaf-header {
padding: 2em 10% 2em;
}
.htmleaf-header h1 {
font-size:1.4em;
}
.htmleaf-links{font-size: 1.4em}
}

@media screen and (max-width: 960px) {
.htmleaf-header {
padding: 2em 10% 2em;
}
.htmleaf-header h1 {
font-size:1.2em;
}
.htmleaf-links{font-size: 1.2em}
.related h3{font-size: 1em;}
.related a h3 {
font-size: 0.8em;
}
}

@media screen and (max-width: 766px) {
.htmleaf-header h1 {
font-size:1.3em;
}
.htmleaf-links{font-size: 1.3em}
}

@media screen and (max-width: 640px) {
.htmleaf-header {
padding: 2em 10% 2em;
}
.htmleaf-header h1 {
font-size:1em;
}
.htmleaf-links{font-size: 1em}
.related h3{font-size: 0.8em;}
.related a h3 {
font-size: 0.6em;
}
}

vue实现登录拦截

首先首页需要用户登录成功,且本地有username的存储,才能进入首页,那么就要在首页的路由中配置拦截。

1、首页路由


{
path: '/',
name: 'home',
component: Home,
meta: {
requireAuth: true //配置拦截
},
},

2、登录页面路由


{
path: '/login',
name: 'login',
component: () => import(/* webpackChunkName: "about" */ '../views/Login.vue')
}

路由钩子函数


router.beforeEach((to,from,next)=>{
if(to.meta.requireAuth){
if(localStorage.getItem('username')){
next();
}else{
next({
path:'/login'
})
}
}else{
next();
}
})

登录页面的验证:


<script>
export default {
name: 'login',
data() {
return {
 username:"",
 psd:'',
 userKey:false,
 psdKey:false
}
},

methods: {
//用户名验证
inputUserBlur(){
 let filter = /^[a-zA-Z0-9_]{6,16}$/;
 console.log('blur');
 if(this.username.trim() == ''){
 this.$message.error('用户名不能为空');
 }else if(!filter.test(this.username)){
 this.$message({
  message: '用户名格式错误(6到16位,字母数字下划线,减号,中间不能有空格)',
  type: 'warning'
 });
 }else{
 this.userKey = true;//用户名格式正确
 }
},
//密码验证
inputPsdBlur(){
 let filter = /^(?![0-9]+$)(?![a-z]+$)(?![A-Z]+$)(?!([^(0-9a-zA-Z)])+$).{6,20}$/;
 console.log('blur');
 if(this.psd.trim() == ''){
 this.$message.error('密码不能为空');
 }else if(!filter.test(this.psd)){
 this.$message({
  message: '密码格式错误(密码包含 数字,英文,字符中的两种以上,长度6-20)',
  type: 'warning'
 });
 }else{
 this.psdKey = true;//密码格式正确
 }
},
//登录
loginBtn(){
 console.log(this.userKey,this.psdKey)
 if(this.userKey && this.psdKey){
 this.$message({
 message: '恭喜你,登录成功',
 type: 'success'
 });
 localStorage.setItem('username',JSON.stringify(this.username));
 this.username = '';
 this.psd = '';
 this.$router.push('/')
 }else{
 this.$message.error('用户名和密码不能为空');
 }
}
},
}
</script>

关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。

来源:https://blog.csdn.net/Hhjian524/article/details/104053861

标签:vue,登录拦截
0
投稿

猜你喜欢

  • Python实现1-9数组形成的结果为100的所有运算式的示例

    2023-04-09 10:52:37
  • Pandas中DataFrame常用操作指南

    2023-08-31 14:14:41
  • 详解Python如何利用turtle绘制中国结

    2021-02-10 13:52:29
  • [翻译]标记语言和样式手册 Chapter 16 下一步

    2008-02-22 17:47:00
  • python实现指定文件夹下的指定文件移动到指定位置

    2023-07-03 08:21:11
  • Java连接sqlserver2008数据库代码

    2023-07-02 10:22:17
  • Python查找不限层级Json数据中某个key或者value的路径方式

    2023-07-08 02:39:43
  • Oracle11.2 命令行手工最简创建数据库的过程

    2009-09-14 12:07:00
  • js阻止移动端页面滚动的两种方法

    2023-08-04 17:36:12
  • 用途相似的标签

    2008-05-23 13:11:00
  • PHP数字前补0的自带函数sprintf 和number_format的用法(详解)

    2024-06-05 09:50:01
  • 如何利用ASP实现邮箱访问

    2007-09-29 12:27:00
  • python3实现elasticsearch批量更新数据

    2021-03-17 19:43:57
  • 浅析Go中序列化与反序列化的基本使用

    2024-02-13 00:40:46
  • Golang空结构体struct{}用途,你知道吗

    2024-04-26 17:36:56
  • Python + selenium自动化环境搭建的完整步骤

    2023-11-19 12:42:57
  • 浅谈Vue使用Cascader级联选择器数据回显中的坑

    2024-04-10 13:47:27
  • 简单易懂的python环境安装教程

    2023-05-21 14:39:16
  • MySQL-MMM安装指南(Multi-Master Replication Manager for MySQL)

    2024-01-19 04:46:03
  • 《Python学习手册》学习总结

    2021-09-17 08:55:01
  • asp之家 网络编程 m.aspxhome.com