中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue實現登錄攔截的方法

發布時間:2020-06-28 10:49:36 來源:億速云 閱讀:286 作者:清晨 欄目:開發技術

這篇文章將為大家詳細講解有關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&#63;rretjt');
 src:url('../fonts/icomoon.eot&#63;#iefixrretjt') format('embedded-opentype'),
  url('../fonts/icomoon.woff&#63;rretjt') format('woff'),
  url('../fonts/icomoon.ttf&#63;rretjt') format('truetype'),
  url('../fonts/icomoon.svg&#63;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 h2 {
 color: #D5D6E2;
 font-weight: 600;
 font-size: 2em;
 line-height: 1;
 margin-bottom: 0;
}
.htmleaf-header h2 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 h4{font-family: "Microsoft YaHei", sans-serif;font-size: 1.2em}
.related a h4 {
 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 h2 {
        font-size:1.4em;
    }
    .htmleaf-links{font-size: 1.4em}
}

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

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

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


首先首頁需要用戶登錄成功,且本地有username的存儲,才能進入首頁,那么就要在首頁的路由中配置攔截。
1、首頁路由

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


2、登錄頁面路由

{
    path: '/login',
    name: 'login',
    component: () => import(/* webpackChunkName: "about" */ '../views/Login.vue')
  }
1
2
3
4
5
路由鉤子函數

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 = /^(&#63;![0-9]+$)(&#63;![a-z]+$)(&#63;![A-Z]+$)(&#63;!([^(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實現登錄攔截的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

灵川县| 济阳县| 德惠市| 康定县| 聂拉木县| 乐都县| 西贡区| 井陉县| 尉犁县| 平果县| 云和县| 阿拉尔市| 达州市| 平陆县| 剑河县| 抚松县| 荥经县| 和龙市| 都江堰市| 平乡县| 梁山县| 清远市| 永宁县| 阿勒泰市| 伊春市| 绥芬河市| 休宁县| 泗水县| 海盐县| 鹤岗市| 阿鲁科尔沁旗| 辽阳市| 永年县| 萨迦县| 沐川县| 平顶山市| 茶陵县| 新闻| 桑植县| 定州市| 洛宁县|