从零开始的后台管理系统

本后台管理系统采用vue cli + element ui 简单搭建

旨在总结自己思路,旁人可能看的不喜欢,但是本意是总结自己思路。

项目框架构建完成后,基础的登入登出实现,然后各个页面的搭建完成路由的跳转有一个整体的视觉效果后,开始思考 要干什么,先解决跨域和代理的问题,因为最终目的是把,接口数据呈现到页kuku

//在config/dev.env.js中
module.exports = merge(prodeEnv,{
    NODE_ENV: '"development"',
    BASE_URL_HTTPS: '"/api/"'
})

//在config/index.js中

'user strict'

const path = require('path')
moudele.exportes={
    dev: {
        //Paths
        assetsSubDirectory: 'static',
        assetsPublicPath:'/',
        proxyTable:{

           '/api':{
                target: ''//你请求的第三方接口
                secure: false,
                secure:  false,
                changeOrigin:true,
                pathRewrite: {
                    '^/api':'/api'
                }
            }    
        },
        host : '0.0.0.0' //内网开发要设置
        port : 8888
    }
}
//在congfig/prod.env.js中
moudele.exports = {
    NODE_ENV: '"production"',
    ENV_CONFIG: '"prod"',
    BASE_URL_HTTPS: ' 你请求的接口地址'
}

 跨域和代理目前就了解这么多 有点菜

然后就是设置api文件夹

api/axiosFun.js中设置请求拦截器和响应拦截器

import axios from "axios" //引入axios

const _axios = axios.create({
    baseURL: process.env.BASE_API,
});
/* 请求拦截器(是在你发起请求之前的操作)*/

_axios.interceptprs.request.use(
    (config) => {
        let token = window.localStorage.getItem("accessTOken")
        console.log('token',token)
        if(token) {
            config.headers.token = token //将token放到请求头发送给服务器
        }
        return config
    },
    (err) => Promise.reject(err)
);

/*响应的操作*/
_axios.interceptors.response.use(
    (res) => {
        console.log(res)
        if(res.data.code === 400){
            
        }
        if(res.data.code === 400){
            
        } else {
            Promise.resolve(res.data)
        }
        return res
    },
       (err) => {
        if(err) {
            console.log(err)
        }
        return Promise.reject(err)
    }
);
export const req = _axios
api/basisMG.js

//登录接口
export const Login = (params) => {
    return req({
        method: 'get',
        params,
        url:'/api/login/login'
   })
}

//退出接口
export const Login = (data) => {
    return req({
        method: 'get',
        data,
        url:'/api/login/logput'
    })
 }

 有了跨域和接口下一步就是把接口数据显示到页面

<template>
    <div class="login-warp">
        <el-form label-position="left" :model="ruleForm" :rules="rules" ref="ruleFrom" label-width="0px" class="demo-ruleFrom">
            <h3>用户登录</h3>
            <el-form-item prop="username">
                <el-input type="text" v-model="ruleForm.username" auto-complete="off" placeholder="账号"></el-input>
            </el-form-item>
            <el-form-item prop="password">
                <el-input type="password" v-model="ruleForm.password" auto-complete="off" placeholder="密码"></el-input>
            </el-form-item>
            <el-checkbox class="remember" v-model="rememberpwd">记住密码</el-checkbox>
           <el-form-item style="width:100%">
              <el-button type="primary" style="width:100%;" @click="submitFrom('ruleFrom')":laoding="logining">登录</el-button> 
            </el-form-item>
        </el-from>
    </div>
</template>

 

<script type="text/ecmascript-6">
    //引入登录接口
    import { Login } from '@api/basisMG'
    export default {
        name: 'login',
        data(){
         return {
             logining:false,
            // 记住密码    
             rememberpwd:false,
             ruleFrom :    {
                    // username 和password默认为空
                    username: '',
                    password: '',          
                },
              rules: {
                    username: [{required:true,message:'请输入账号',trigger:'blur'}],
                    password: [{required:true,message:'请输入密码',trigger:'blur'}],
                }
            }   
        },
        created(){},
        methods: {
            //获取info列表
            submitForm(forName){
                console.log('formName'+formName);
                this.$refs[formName].validate(valid =>{
                    if(valid){
                        this.logining = true
                        //调用接口啦!!
                        Login(this.ruleForm).then(res => {
                            if(res.data.code === 200){
                                this.logining = false
                                this.$store.commit('login',true)
                                this.$router.push({path:'/goods/Goods'})
                                let accseeToken = res.data.data.token, //从
                                console.log(accessTOken)
                                localStorage.setItem('accessToken',accessToken)//用localhost缓存token值
                            }else{
                                this.$store.commit('login','false')
                                this.loadining = false
                                this.$message('用户密码不对')
                            }
                        })
                    }
                })
            }
        }
    }
</script>

再感悟一个页面

<template>
    <div>
        <el-breadcrumb separator-class="el-icon-arrow-right">
            <el-breadcrumb-item :to="{path:'/'}">首页</el-breadcrumb-item>
            <el-breadcrumb-item>用户管理</el-breadcrumb-item>
        </el-treadcrumb>
        <template>
            <div class="basetable" v-loading="loading" element-loading-text="拼命加载中">
                // v-loading 设置加载
                <div class="selectMenu">
                    //绑定的点击事件中,调用封装好的axios接口
                    <el-button type="primary" @click="add">新增</el-button>
                    <el-button type="primary" @click="queryList">查询列表</el-button>
                </div>
                <div class="tableMain">
                    <el-table :data="tableData" style="width:100%">
                        <el-table-colunm prop="username" label="姓名" width="180"></el-table-column>
                        <el-table-column prop="password" label="密码" width="180"><el-table-column>
                        <el-table-column prop="email" label="邮箱"></el-table-column>
                        <el-table-column prop="updateTime" label="更新时间"></el-table-column>
                        <el-table-column label="操作">
                            <template slot-scope="scope">
                                <el-button size="small" @click="handleEdit(scope.$index,scope.row)">编辑</el-button>、
                                <el-button size="small" type="danger" @click="handlDelete(scope.$index,scope.row)">删除</el-button>
                            </template>
                        <el-table-column>
                    </el-table>
                    <div>
                        <el-dialog title="用户信息" :visible.sync="dialogFormVIsible">
                        //在el-dialog中进行el-from嵌套实现弹出表格效果
                      <el-form :model="form">
                         <el-form-item label="用户名" :label-width="formLabelWidth">
                         <el-input v-model="form.username" auto-complete="off"></el-input>
                        </el-form-item>
                        <el-form-item label="密码" :label-width="formLabelWidth">
                         <el-input v-model="form.password" auto-complete="off"></el-input>
                        </el-form-item>
                        <el-form-item label="邮箱" :label-width="formLabelWidth">
                         <el-input v-model="form.email" auto-complete="off"></el-input>
                        </el-form-item>
                      </el-form>
                          <div slot="footer" class="dialog-footer">
                             <el-button @click="cancel">取 消</el-button>
                                <!-- 设置触发更新的方法 -->
                            <el-button type="primary" @click="add">确 定</el-button>
                          </div>
                        </el-dialog>
                    </div>
                </div>
            </div>
        </template>
    </div>
</template>

js

<script>
    import {adduser,updateuser,selectpage,deleteuser} from '@/api/basisMG'
    //导入请求方法
    export default {
        return {
            loading:true
            //表格数据
            tableteData:[],
            dialogFromVisible: false,
            formLabelWidth:"80px"m
            
            //设置form用于进行添加时候绑定值 添加用
            form: {
                username: '',
                password: '',
                email: ''
            },
            //修改用
            data: {
               "uuid": 'oee15707-9acb-4b09-b205-3f2014ca41ba',
                "password": '23456',
                "email": '898888@qq.com'
            },
            //删除用
            data2:{
                 "uuid": "0ee15707-9acb-4b09-b205-3f2014ca41ba"
            },
            //查询列表用
            data3: {
                "pageSize": 10,
                "pageNum":1,
                 "username":' ,       
            },
            value6:"",
            currentPage3:1,
            currentINdex:""
        }    
    },
    creat(){
        setTimeout(()=> {
            this.loading = false;
        },1500)    
    },

    methods: {
    showTime() {
      this.$alert(this.value6, "起止时间", {
        confirmButtonText: "确定",
        callback: action => {
          this.$message({
            type: "info",
            message: "已显示"
          });
        }
      });
    },

    //查看列表界面,需要验证
    queryList(){
      selectpage(this.date3).then(res => {
       this.tableData= res.data.data.records
        console.log("shuju========="+JSON.stringify(this.tableData))

      })

    },
    // 增加数据的方式,单独的设置一些值,用于增加功能,这些值放在对象里面进行设置,然后将这个新增的对象塞到总数据里面
    add() {
      adduser(this.form).then(res => {
        console.log("表单JSON数据====="+JSON.stringify(this.form))
        // alert(JSON.stringify(res))
      })
      //   设置点击按钮之后进行显示对话框
      this.dialogFormVisible = true;
      
    },

    //更新操作,把页面的值带入
    update() {
      updateuser(this.data).then(res => {
        console.log("表单JSON数据====="+JSON.stringify(this.data))
        alert(JSON.stringify(res))

      })
    },

    //删除用户
    deteleUser(){
      deleteuser(this.data2).then(res => {
        console.log("表单JSON数据====="+JSON.stringify(this.data))
        alert(JSON.stringify(res))

      })
    },
    handleEdit(index, row) {
      // 将数据的index传递过来用于实现数据的回显
      this.form = this.tableData[index];
      this.currentIndex = index;
      // 设置对话框的可见
      this.dialogFormVisible = true;
    },
    handleDelete(index, row) {
      // 设置类似于console类型的功能
      this.$confirm("永久删除该用户, 是否继续?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      })
        .then(() => {
          // 移除对应索引位置的数据,可以对row进行设置向后台请求删除数据
          this.tableData.splice(index, 1);
          this.$message({
            type: "success",
            message: "删除成功!"
          });
        })
        .catch(() => {
          this.$message({
            type: "info",
            message: "已取消删除"
          });
        });
    },
    cancel() {
      // 取消的时候直接设置对话框不可见即可
      this.dialogFormVisible = false;
    },
    // handleSizeChange(val) {
    //   console.log(`每页 ${val} 条`);
    // },
    // handleCurrentChange(val) {
    //   console.log(`当前页: ${val}`);
    // }
  }
}
    </script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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、付费专栏及课程。

余额充值