Vue模拟登录

news/2024/7/9 23:42:38 标签: vue, 前端

路由规则

const router = new VueRouter({
  routes: [
    { path: '/', redirect: '/login' },
    // 登录的路由规则
    { path: '/login', component: Login },
    // 后台主页的路由规则
    {
      path: '/home',
      component: Home,
      redirect: '/home/users',
      children: [
        { path: 'users', component: Users },
        { path: 'rights', component: Rights },
        { path: 'goods', component: Goods },
        { path: 'orders', component: Orders },
        { path: 'settings', component: Settings },
        // 用户详情页的路由规则
        { path: 'userinfo/:id', component: UserDetail, props: true }
      ]
    }
  ]
})

// 全局前置守卫
router.beforeEach(function(to, from, next) {
  if (pathArr.indexOf(to.path) !== -1) {
    const token = localStorage.getItem('token')
    if (token) {
      next()
    } else {
      next('/login')
    }
  } else {
    next()
  }
})

pathArr.js

export default ['/home', '/home/users', '/home/rights']

vue_47">Login.vue

<template>
  <div class="login-container">
    <div class="login-box">
      <!-- 头像区域 -->
      <div class="text-center avatar-box">
        <img src="../assets/logo.png" class="img-thumbnail avatar" alt="" />
      </div>

      <!-- 表单区域 -->
      <div class="form-login p-4">
        <!-- 登录名称 -->
        <div class="form-group form-inline">
          <label for="username">登录名称</label>
          <input
            type="text"
            class="form-control ml-2"
            id="username"
            placeholder="请输入登录名称"
            autocomplete="off"
            v-model.trim="username"
          />
        </div>
        <!-- 登录密码 -->
        <div class="form-group form-inline">
          <label for="password">登录密码</label>
          <input
            type="password"
            class="form-control ml-2"
            id="password"
            placeholder="请输入登录密码"
            v-model.trim="password"
          />
        </div>
        <!-- 登录和重置按钮 -->
        <div class="form-group form-inline d-flex justify-content-end">
          <button type="button" class="btn btn-secondary mr-2" @click="reset">重置</button>
          <button type="button" class="btn btn-primary" @click="login">登录</button>
        </div>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  name: 'MyLogin',
  data() {
    return {
      username: '',
      password: ''
    }
  },
  methods: {
    reset() {
      this.username = ''
      this.password = ''
    },
    login() {
      if (this.username === 'admin' && this.password === '666666') {
        // 登录成功
        // 1. 存储 token
        localStorage.setItem('token', 'Bearer xxxx')
        // 2. 跳转到后台主页
        this.$router.push('/home')
      } else {
        // 登录失败
        localStorage.removeItem('token')
      }
    }
  }
}
</script>

<style lang="less" scoped>
.login-container {
  background-color: #35495e;
  height: 100%;
  .login-box {
    width: 400px;
    height: 250px;
    background-color: #fff;
    border-radius: 3px;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    box-shadow: 0 0 6px rgba(255, 255, 255, 0.5);
    .form-login {
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      box-sizing: border-box;
    }
  }
}

.form-control {
  flex: 1;
}

.avatar-box {
  position: absolute;
  width: 100%;
  top: -65px;
  left: 0;
  .avatar {
    width: 120px;
    height: 120px;
    border-radius: 50% !important;
    box-shadow: 0 0 6px #efefef;
  }
}
</style>

退出登录

<template>
  <div class="layout-header-container d-flex justify-content-between align-items-center p-3">
    <!-- 左侧 logo 和 标题区域 -->
    <div class="layout-header-left d-flex align-items-center user-select-none">
      <!-- logo -->
      <img class="layout-header-left-img" src="../../assets/heima.png" alt="" />
      <!-- 标题 -->
      <h4 class="layout-header-left-title ml-3">黑马后台管理系统</h4>
    </div>

    <!-- 右侧按钮区域 -->
    <div class="layout-header-right">
      <button type="button" class="btn btn-light" @click="logout">退出登录</button>
    </div>
  </div>
</template>

<script>
export default {
  name: 'MyHeader',
  methods: {
    logout() {
      // 1. 清空 token
      localStorage.removeItem('token')
      // 2. 跳转到登录页面
      this.$router.push('/login')
    }
  }
}
</script>

<style lang="less" scoped>
.layout-header-container {
  height: 60px;
  border-bottom: 1px solid #eaeaea;
}

.layout-header-left-img {
  height: 50px;
}
</style>


http://www.niftyadmin.cn/n/563852.html

相关文章

Node.js----前后端的身份认证(session与jwt)

Node.js----前后端的身份认证 session与jwt 1 Web 开发模式1.1 服务端渲染的 Web 开发模式1.1.1 服务端渲染的优缺点1.2 前后端分离的 Web 开发模式1.2.1 前后端分离的优缺点1.3 Web 开发模式的选择2 身份认证2.1不同开发模式下的身份认证3 Session 认证机制3.1 HTTP 协议的无状…

什么是云服务器?腾讯云轻量应用服务器与云服务器有什么区别?

首先&#xff0c;什么是云服务器&#xff1f; 云服务器是在云中提供可扩展的计算服务&#xff0c;避免了使用传统服务器时需要预估资源用量及前期投入的情况。云服务器支持用户自定义一切资源&#xff1a;cpu、内存、硬盘、网络、安全等等&#xff0c;并可在访问量和负载等需求…

Vue----组件基础

Vue----组件基础1 单页面应用程序1.1 什么是单页面应用程序1.2 单页面应用程序的特点1.3 单页面应用程序的优缺点1.3.1 单页面应用程序的优点1.3.2 单页面应用程序的缺点1.4 如何快速创建 vue 的 SPA 项目2 vite 的基本使用2.1 创建 vite 的项目2.1.1 在对应的文件夹下打开命令…

Node.js----模块化

Node.js----模块化1 模块化的基本概念1.1 模块化1.2 模块化规范2 Node.js 中模块化2.1 Node.js 中模块的分类2.2 加载模块2.3 Node.js 中的模块作用域2.3.1 模块作用域2.3.2 模块作用域的好处2.4 向外共享模块作用域中的成员2.4.1 module 对象2.4.2 module.exports 对象2.4.3 e…

js编程时常见问题解决方法

js编程时常见问题解决方法时间格式化包nodejs格式化时间挂载为全局中间件nodemon报错接收请求时&#xff0c;请求的参数为未定义滚动到底部时间格式化的包安装axios出现报错&#xff1a;nodejs请求表单解析返回错误信息的中间件nodejs错误中间件nodejs mysql模块时间格式化包 …

Node.js----npm与包

Node.js----npm与包1 包1.1 什么是包1.2 包的来源1.3 包的作用1.4 从哪里下载包1.5 如何下载包2 安装使用包2.1 在项目中安装包的命令2.1.1 安装指定版本的包2.1.2 包的语义化版本规范2.2 导入包2.3 使用包3 包管理配置文件3.1 记录项目中安装了哪些包3.2 快速创建 package.jso…

怎么做网站?网站用什么服务器好?

对于网站&#xff0c;大家可能并不陌生&#xff0c;它是如何做出来的&#xff0c;相信很多人可能不知道。做一个网站必须的是域名、服务器、网站源码&#xff0c;域名就是跟我们aliyun168.com ,这个就是域名&#xff0c;每个网站都是有自己专属的域名&#xff0c;也是唯一的&am…

服务器基础知识【初学者必看】

摘要&#xff1a; 什么是服务器 就像他的名字一样&#xff0c;服务器在网络上为不同用户提供不同内容的信息、资料和文件。可以说服务器就是Internet网络上的资源仓库&#xff0c;正是因为有着种类繁多数量庞大内容丰富的服务器的存在&#xff0c;才使得Internet如此的绚丽多彩…