从零编写 vue 后台管理系统(02)

文件目录

我们要在src 文件夹操作这些内容。

├─api               // 所有请求
├─assets            // 主题 字体等静态资源
├─components        // 全局公用组件
├─layout            // 导航栏
├─router           // 路由
├─store            // 全局 store管理
├─utils            // 全局公用方法
├─views            // view
    └─login        //登录页面
└─main.js            // 主方法

utils

根据个人习惯,首先我们 新建 util 文件夹,编写公用方法。

在vue项目中,和后台交互获取数据这块,我们通常使用的是axios库,它是基于promise的http库,可运行在浏览器端和node.js中。他有很多优秀的特性,例如拦截请求和响应、取消请求、转换json、客户端防御XSRF等。
每次使用axios是都要把所有的配置写一遍很是麻烦且不方便维护。所以将axios封装一下方便使用。这是我用的一个简单的封装模板:

import axios from 'axios';

// 创建axios实例
const service = axios.create({
  baseURL: process.env.BASE_API, // 最终 url = base url + request url
  //process.env.BASE_API 在 config 下的 dev.env.js 中设置
  //request url 后面说到
  // withCredentials: true, // 跨域请求时发送Cookie
  timeout: 5000 // //设置接口响应时间
})
//http request 拦截器
axios.interceptors.request.use(
  config => {
  // 可以对下面的数据进行操作
  //config.method        请求类型
  //config.url           请求路径
  //config.headers       请求头
  //config.data          请求数据
    return config;
  },
  error => {
   //发生错误时执行
    return Promise.reject(err);
  }
);
//http response 拦截器
axios.interceptors.response.use(
  response => {
  // 可以对下面的数据进行操作
   //response.status     请求返回状态
   //response.data       请求返回数据
    return response;
  },
  error => {
   //发生错误时执行
    return Promise.reject(error)
  }
)


/**
 * 封装get方法
 * @param url
 * @param data
 * @returns {Promise}
 */

export function fetch(url,params={}){
  return new Promise((resolve,reject) => {
    axios.get(url,{
      params:params
    })
    .then(response => {
      resolve(response.data);
    })
    .catch(err => {
      reject(err)
    })
  })
}

/**
 * 封装post请求
 * @param url
 * @param data
 * @returns {Promise}
 */

 export function post(url,data = {}){
   return new Promise((resolve,reject) => {
     axios.post(url,data)
          .then(response => {
            resolve(response.data);
          },err => {
            reject(err)
          })
   })
 }
 /**
 * 封装patch请求
 * @param url
 * @param data
 * @returns {Promise}
 */

export function patch(url,data = {}){
  return new Promise((resolve,reject) => {
    axios.patch(url,data)
         .then(response => {
           resolve(response.data);
         },err => {
           reject(err)
         })
  })
}

 /**
 * 封装put请求
 * @param url
 * @param data
 * @returns {Promise}
 */

export function put(url,data = {}){
  return new Promise((resolve,reject) => {
    axios.put(url,data)
         .then(response => {
           resolve(response.data);
         },err => {
           reject(err)
         })
  })
}
//暴露接口
export default service

这是一个 包括了 request ;response 以及get ;post ;patch ;put 的简单 axios 封装。
我们现在只是登录,没有太多需求,就按照默认的来。
在 utils 文件夹下新建 js request.js 。用来封装 axios。代码:

import axios from 'axios'

const service = axios.create({
  baseURL: process.env.VUE_APP_BASE_API,
  timeout: 5000
})
service.interceptors.request.use(
  config => {
    return config
  },
  error => {
    console.log(error)
    return Promise.reject(error)
  }
)

service.interceptors.response.use(
  /**
   * If you want to get http information such as headers or status
   * Please return  response => response
  */

  /**
   * Determine the request status by custom code
   * Here is just an example
   * You can also judge the status by HTTP Status Code
   */
  response => {
    const res = response.data
    //如果自定义代码不是20000,则判断为错误。
    if (res.code !== 20000) {
      Message({
        message: res.message || 'Error',
        type: 'error',
        duration: 5 * 1000
      })//提示错误
      return Promise.reject(new Error(res.message || 'Error'))//返回一个错误
    } else {
      return res
    }
  },
  error => {
   return Promise.reject(error)
  }
)
export default service

后台在验证登录成功后传回的是:

{
code: 20000,
data: {
		token: "admin-token"
	}
}

密码或密码错误则是:

{
code: 60204,
message: "Account and password are incorrect."
}

api

上面封装的 request 我们这里来使用。
我们来写登录方法。非常简单,只用调用上面的 request 即可。
在 api 文件夹 下新建 js 文件 user.js。

import request from '@/utils/request'

export function loginByUsername(data) {
  return request({
    url: 'admin/user/login',  //上文的 request url
    method: 'post',           // 请求方式
    data                      //请求数据
  })
}

这样我们就后台登录我就完成了。后台的响应逻辑我们后面讲。

store

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式;集中存储和管理应用的所有组件状态。每一个Vuex应用的核心就是store(仓库)。store 基本上就是一个容器,包含着应用中大部分的state(状态)。

Vuex和单纯的全局对象有以下两点不同:

Vuex 的状态存储是响应式的。当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高效更新。
不能直接改变 store 中的状态。改变 store 中的状态的唯一途径就是显式地提交 mutation。这样使得我们可以方便地跟踪每一个状态的变化,从而让我们能够实现一些工具帮助我们更好地了解我们的应用。

基本用法:

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const store = new Vuex.Store({
  state: {
    // 存放状态
  },
  getters: {
    // state的计算属性
  },
  mutations: {
    // 更改state中状态的逻辑,同步操作
  },
  actions: {
    // 提交mutation,异步操作
    
  },
  // 如果将store分成一个个的模块的话,则需要用到modules。
   //然后在每一个module中写state, getters, mutations, actions等。
  modules: {
    a: moduleA,
    b: moduleB,
    // ...
  }
});

根据我们的登录需求。当用户填写完账号和密码后向服务端验证是否正确,验证通过之后,服务端会返回一个token。我们需要存储 token 使它在全部页面可用。
在 store 页面新建 js 文件 index.js。

import Vue from 'vue'
import Vuex from 'vuex'
import {  loginByUsername  } from '@/api/user'
Vue.use(Vuex)

const store = new Vuex.Store({
  state: {
    // 存放状态
    token: ''
  },
  getters: {
    //获取到用户状态,//实时监听state值的变化(最新状态)
    GetToken: state => state.token

  },
  mutations: {
    // 更改state中状态的逻辑,同步操作
    SET_TOKEN: (state, token) => {
      state.token = token
    }
  },
  actions: {
    // 提交mutation,异步操作
    LoginByUsername({  commit  }, userInfo) {
      const username = userInfo.username.trim()
      return new Promise((resolve, reject) => {
        loginByUsername({username : username,password: userInfo.password}).then(response => {
          const data = response.data
          commit('SET_TOKEN', data.token)//mutations中的方法
          resolve()
        }).catch(error => {
          console.log('token err')
          reject(error)
        });
      });
    }
  }
})

export default store

我们完成了登录的全部处理,现在开始写页面。
在 views/login 文件夹下新建vue文件 index.vue。
随便在页面撸上两个input的框,一个是登录账号,一个是登录密码。再放置一个登录按钮。我们将登录按钮上绑上click事件,点击登录之后调用 store 的登录方法提交账号和密码进行验证。

<template>
  <div>
    <input type="text" v-model="loginForm.username" placeholder="用户名" />
    <input type="text" v-model="loginForm.password" placeholder="密码" />
    <button @click="handleLogin">登录</button>
  </div>
</template>

<script>
export default {
  name: 'Login',
  data () {
    return {
      loginForm: {
        username: 'admin',
        password: '111111'
      }
    }
  },
  methods: {
    handleLogin: function () {
      console.log('login' + this.loginForm)
      // this.$store.dispatch('LoginByUsername') 调用 store 下 actions 中的LoginByUsername方法。
      this.$store.dispatch('LoginByUsername', this.loginForm).then(() => {
        this.$router.push({
          path: '/'
        }) // 登录成功之后重定向到首页
      }).catch((err) => {
        console.log(err) // 登录失败提示错误
      })
    }
  }
}
</script>

一个简单的登录页面完成。

layout

这里应该放导航栏,现在只是简单的做一个登录 没有必要写太复杂,简单的写一下就行。
在 layout 文件夹下 新建 vue 文件 index.vue。

<template>
  <div> layout</div>
</template>

<script>
</script>

<style>
</style>

就这么简单就ok了。

router

import Vue from 'vue'
import Router from 'vue-router'

Vue.use(Router)
import Foo from '../views/foo'
// 每个路由应该映射一个组件。 其中"component" 可以是通过 Vue.extend() 创建的组件构造器,或者,只是一个组件配置对象。
const routes = [
  { path: '/foo', component: Foo },
  { path: '/bar', component: () => import('@/views/AMap')}
]

//创建 router 实例,然后传 `routes` 配置
const router = new VueRouter({
  routes: routes
})

我们简单的编写一下路由。
在 router 文件夹下 新建 js 文件 index.js。

import Vue from 'vue'
import Router from 'vue-router'

Vue.use(Router)
import Layout from '@/layout'
import Login from '../views/login/';
export const constantRouterMap = [
  { path: '/login', component: Login },
  { path: '/',component: Layout },
]
export default new Router({
  routes: constantRouterMap
});

main.js

我们在全局钩子router.beforeEach中拦截路由,判断是否已获得token,如果没有则进入login页面。

router.beforeEach((to, from, next) => {
  // do something 
  next();
});

每个钩子方法接收三个参数:
to: Route: 即将要进入的目标路由对象
from: Route: 当前导航正要离开的路由
next: Function: 一定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数。
我们修改main.js 文件:

import Vue from 'vue'
import App from './App'
import router from './router'

import ElementUI from 'element-ui'

import store from './store'
Vue.config.productionTip = false

const whiteList = ['/login']

router.beforeEach(async (to, from, next) => {
  const hasToken = store.getters.GetToken
  console.log('getToken' + hasToken)
  if (!hasToken) {
    if (whiteList.indexOf(to.path) !== -1) {
      next()
    } else {
      next(`/login`)
    }
  } else {
    next()
  }

})
Vue.use(ElementUI)
/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  store,  //引入到vue中
  components: {
    App
  },
  template: '<App/>'
})

运行

所有的编写就完成了。可以运行查看了。
在运行前 先 install 一下。

进入页面:
在这里插入图片描述
账号或密码错误提示:
在这里插入图片描述

登录成功页面:
在这里插入图片描述

其他

如果 selint 报错。可以在 config/inedx.js 中 useEslint 设为 false。

后端框架可以使用 Spring Boot;.NET ;Flask。 编写。当然,最好使用 mock。
mock 逻辑:

const tokens = {
  admin: {
    token: 'admin-token'
  },
  editor: {
    token: 'editor-token'
  }
}
module.exports = [
  // user login
  {
    url: 'admin/user/login',
    type: 'post',
    response: config => {
      const { username } = config.body
      const token = tokens[username]

      // mock error
      if (!token) {
        return {
          code: 60204,
          message: 'Account and password are incorrect.'
        }
      }

      return {
        code: 20000,
        data: token
      }
    }
  }]

仅仅 mock 登录逻辑,具体实现请完善。

### 回答1: Vue 3 和 Spring Boot 是一对强大的技术组合,可用于搭建现代化的后台管理系统。下面是一个基本的指南,介绍如何从开始搭建一个 Vue 3 + Spring Boot 后台管理系统。 首先,我们需要准备开发环境。在电脑上安装好 Node.js 和 Java JDK,并配置好环境变量。然后,安装 Vue CLI 和 Spring Boot CLI,这些工具将帮助我们创建和管理项目。 第二步是创建一个新的 Spring Boot 项目。使用 Spring Boot CLI,我们可以快速创建一个空的 Spring Boot 项目,并进行基本的配置。可以使用命令行,输入如下命令来创建项目: ``` $ spring init --name=my-project --groupId=com.example --artifactId=my-project --dependencies=web my-project ``` 这将创建一个名为 my-project 的 Spring Boot 项目。 接下来,我们可以创建一个 Vue 3 项目。使用 Vue CLI,我们可以选择一个预定义的模板,例如 Vue Router 和 Vuex,以及一些常用的插件。可以使用命令行,输入如下命令来创建项目: ``` $ vue create my-project ``` 这将创建一个名为 my-project 的 Vue 3 项目。 现在,我们已经有了一个空的 Spring Boot 项目和一个空的 Vue 3 项目。接下来,我们需要将这两者连接起来。 在 Vue 3 项目中,可以使用 axios 或者 fetch 来发送请求到后端。在 Spring Boot 项目中,可以使用 Spring Data JPA 来管理数据库,Spring Boot Security 来进行身份验证和授权。 我们可以编写 RESTful API 接口,用于在前端和后端之间传输数据。同时,也需要编写前端组件和页面,以及后端的 Controller 和 Service 层代码,来实现各种功能。 最后,我们可以使用打包和部署工具,将项目打包为可部署的文件,并将其部署到服务器上。例如,可以使用 Maven 将 Spring Boot 项目打包为 Java 可执行文件(JAR 文件),并使用 Nginx 或 Apache 将 Vue 3 项目部署为静态文件。 总之,使用 Vue 3 和 Spring Boot 可以快速搭建一个功能丰富的后台管理系统。只需按照上述步骤创建项目、编写代码、连接前后端,最后打包部署即可。当然,在实际开发过程中还需要考虑安全性、性能优化和代码质量等方面的问题,这些都需要进一步的学习和实践。 ### 回答2: Vue3是一个流行的JavaScript框架,用于构建用户界面。Spring Boot是一个基于Java的框架,用于构建快速且易于配置的应用程序。下面是在Vue3和Spring Boot中从搭建后台管理系统的步骤: 1. 搭建Spring Boot后端: - 在IDE中创建一个新的Spring Boot项目。 - 添加所需的依赖项,如Spring Security、Spring Data JPA和MySQL数据库驱动程序。 - 创建实体类和存储库接口,用于管理系统数据的持久化。 - 创建控制器类,用于处理来自前端的请求,并调用适当的服务方法。 - 配置数据库连接和安全性设置。 - 运行应用程序,确保后端正常工作。 2. 搭建Vue3前端: - 在命令行中使用Vue CLI创建一个新的Vue3项目。 - 在Vue3项目中安装所需的依赖项,如Vue Router和Axios。 - 创建路由配置文件,定义前端路由和对应的组件。 - 创建后台API服务文件,使用Axios发送HTTP请求到后端。 - 创建所需的组件,如登录、注册、用户管理和权限管理。 - 配置应用程序的主要入口点,并将路由和组件添加到Vue实例中。 - 运行应用程序,确保前端正常工作。 3. 连接前端和后端: - 在Vue3中使用Axios调用后端API。 - 在Spring Boot中创建适当的控制器和服务方法,以接收和处理来自前端的请求。 - 在Vue3中处理返回的数据,并根据需要进行展示和处理。 4. 完善功能和界面设计: - 根据系统需求和设计规范,完善后台管理系统的功能和界面。 - 添加用户认证和授权功能,确保只有授权用户才能访问特定页面和功能。 - 使用Vue3的组件化和响应式特性,实现良好的用户体验。 - 进行测试和调试,确保系统稳定性和安全性。 以上是使用Vue3和Spring Boot搭建后台管理系统的一般步骤,具体的实施过程可能因项目需求和个人偏好而有所不同。在开始搭建项目之前,建议先了解Vue3和Spring Boot的基本知识,并参考官方文档和教程,以帮助顺利完成项目。 ### 回答3: 搭建一个基于Vue3和Spring Boot的后台管理系统,需要经过以下步骤: 1. 确保你已经安装了Node.js和Java开发环境。可以从官网上下载并按照指引进行安装。 2. 创建Vue3项目。使用命令行工具或者Vue CLI来创建一个新的Vue3项目。运行命令`vue create project-name`,然后根据指引选择需要的配置项,比如包管理工具、路由、状态管理等。等待项目创建完成。 3. 构建前端界面。在Vue3项目中,根据需求使用Vue组件来搭建前端界面。可以使用Vue3提供的Composition API来编写组件逻辑,通过Vue Router来管理路由,使用Vuex来管理状态。 4. 编写API接口。使用Spring Boot来构建后端服务。创建一个Spring Boot项目,添加所需的依赖,如Spring Web、Spring Data JPA等。编写API接口的Controller类,定义各个接口的URL映射和请求处理方法。 5. 连接数据库。使用Spring Data JPA或其他适当的技术在后台系统中连接数据库。配置数据库连接信息,创建实体类和仓库接口,实现对数据库的增删改查操作。 6. 实现前后端交互。在Vue3项目中,使用axios或其他合适的HTTP库发送HTTP请求到后端接口,获取数据并进行展示。前端页面通过调用API接口来实现数据的增删改查操作。 7. 运行和部署。在开发过程中可以使用命令行运行Vue3前端项目和Spring Boot后端项目,通过不同的端口来访问前后端。在开发完成后,可以使用打包工具如Webpack将前端项目打包成静态文件,然后将打包结果部署到服务器,运行Spring Boot项目。 通过以上步骤,你就可以搭建一个基于Vue3和Spring Boot的后台管理系统。这个系统可以实现前后端分离,通过API接口进行数据交互,具备良好的可扩展性和可维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值