三天快速搭建一个属于自己的管理系统,包括前端、后端、部署上线,超级详细的介绍。

4 篇文章 1 订阅
3 篇文章 0 订阅

最近在做一个关于盲文打印机的项目,需要给app开发一个后台管理系统。目前基本功能已经实现,前前后后大概三天左右,后续还会继续添加功能、优化系统。

目前使用的技术栈:vue3、js、springboot、MP

此次开发使用了Fantastic-admin 管理系统框架基础版。一款优秀的框架会极大提高开发效率!

基础版免费,专业版也只有几百块、功能十分强大!有能力有需要的可以直接上专业版。

Fantastic - admin 管理系统框架下载、使用可以看我之前发的文章安利一个非常优秀的开源后台管理系统项目,开箱即用,极大提高效率https://blog.csdn.net/qq_61672548/article/details/125704550?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522167974621716800192213117%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fblog.%2522%257D&request_id=167974621716800192213117&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~blog~first_rank_ecpm_v1~rank_v31_ecpm-1-125704550-null-null.article_score_rank_blog&utm_term=fantastic&spm=1018.2226.3001.4450

Fantastic - admin 官网: Fantastic-admin | 一款 Vue 中后台管理系统框架一款开箱即用的 Vue 中后台管理系统框架,采用 Vue3 + Vite2 技术栈。https://hooray.gitee.io/fantastic-admin/?from=element-plus

toBraille后台管理系统功能简洁

1.登录注册,这没有什么好说的。Fantasitc已经给提供好了,包括登录校验、账号缓存、权限检查... 我们只需把注册的数据上传到我们的数据库,登录的时候再去数据库校验。

这里设定了两种身份,admin 和 其他身份展现的内容不一样,admin有所有权限。

用v-show实现 。但其实使用 v - if 在这种环境更合适 ,因为当 v - show 是false时,是加了一个 display :none 。元素还是在的,只是看不到了。 v - if 的话,当是 false 直接把元素销毁了,true的时候在重新创建 ,如果v - if 需要在true 和 false 变化很频繁的话这就很消耗性能。   

这里提醒一下大家Fantasic - admin 对axios封装了一个 api ,使用方式还是一样的,比如 api.get。 但是它对所有请求数据进行了一个拦截检查,注意src/api/index.js 里面有一个全局拦截。

Fanstic - admin 定义的标准返回格式为:{ status: 1, error: '', data: '' }

如果你后端返回的格式是{ code :1,data:} ,经过拦截的时候你没有status,则status肯定不会 1 ,它就认为这是一个错误返回,你的 api.get(' X X') .then(res = > { }) 里面的res就没有值。

这里折磨我挺久。

下面图我已经换成我习惯的返回格式。

下面贴上我前端处理登录的方法 ,和后端接收的方法 。

@RestController
@RequestMapping("/login")
@CrossOrigin
public class Login {
    @Autowired
    private BackstageUserServiceInterface userServiceInterface;

    @RequestMapping
    public R<String> login(@RequestBody BackstageUser user) {
        LambdaQueryWrapper<BackstageUser> wrapper = new LambdaQueryWrapper<>();
        wrapper.eq(BackstageUser::getAccount, user.getAccount());
        BackstageUser one = userServiceInterface.getOne(wrapper);
        if (one == null) {
            return R.error("该手机号未注册!");
        } else {
            if (user.getPassword().equals(one.getPassword()) ) {
                return R.success("登录成功!");
            } else {
                return R.error("密码错误!");
            }
        }
    }
}

function handleLogin() {
    if (loginForm.value.account == 'admin' || loginForm.value.account == 'test') {
        loading.value = true
        userStore.login(loginForm.value).then(() => {
            loading.value = false
            if (loginForm.value.remember) {
                localStorage.setItem('login_account', loginForm.value.account)
            } else {
                localStorage.removeItem('login_account')
            }
            localStorage.setItem('account', loginForm.value.account)
            router.push(redirect.value)
        }).catch(() => {
            loading.value = false
        })
    } else {

        proxy.$refs.loginFormRef.validate(valid => {
            if (valid) {
                api.post('login', loginForm.value).then(res => {
                    if (res.code == 1) {
                        loading.value = true
                        userStore.login(loginForm.value).then(() => {
                            loading.value = false
                            if (loginForm.value.remember) {
                                localStorage.setItem('login_account', loginForm.value.account)
                            } else {
                                localStorage.removeItem('login_account')
                            }
                            ElMessage({
                                message: res.data,
                                type: 'success'
                            })
                            setTimeout(router.push(redirect.value), 1000)
                        }).catch(() => {
                            loading.value = false
                        })
                    } else {
                        ElMessage({
                            message: res.data,
                            type: 'error'
                        })
                    }
                })

            }
        })
    }

}

 2.首页  没什么特别的,我觉得比较好看的就是加了一个 transform 样式,在鼠标接触到的时候有一个3D感觉。

.head:hover {

    transform: translateY(-2px) scale(1.01);

    box-shadow: 0 14px 24px rgb(0 0 0 / 20%);

    border-radius: 10px;

}

3.列表 使用的 el-table 也没有任何讲的

 

4.数据统计功能,主要使用了echarts,实现还是很简单。对于echarts的使用看我这篇博客 vue3中使用echart的两种引入方式,以及需要注意的事项。https://blog.csdn.net/qq_61672548/article/details/125746240?spm=1001.2014.3001.5501

  • 5
    点赞
  • 85
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 为了搭建一个网站前端框架和后端管理系统,可以使用前端框架如React、Vue或Angular,而后端管理系统可以使用Node.js或PHP来构建,可以使用RESTful API和JSON来连接前后端。另外,为了让前端后端更好的协作,可以使用数据库系统(如MySQL)来存储、管理和处理数据。 ### 回答2: 搭建一个完整的网站需要考虑前端框架和后端管理系统的配合使用。下面是一个简单的搭建过程及配合使用的方式。 第一步:选择前端框架 首先,根据项目需求选择合适的前端框架,常用的有React、Vue、Angular等。然后,通过npm或者yarn等包管理工具安装前端框架,并创建一个新的项目。 第二步:搭建前端页面 在前端项目中,根据设计稿进行页面布局和样式设计,引入合适的UI组件库,编写页面的HTML、CSS和JavaScript代码。使用前端框架的组件和路由功能,实现页面的模块化和动态路由。 第三步:选择后端管理系统 根据项目需求选择合适的后端管理系统,比如Django、Laravel、Spring Boot等。后端管理系统可以提供用户认证、权限管理、数据管理等功能。 第四步:设计数据库 在后端管理系统中,设计数据库结构并创建数据库表,定义表之间的关系。使用ORM工具,如Django的ORM,操作数据库,实现数据的增删改查。 第五步:实现前后端的数据交互 通过前端框架的网络请求功能,与后端管理系统进行数据交互。前端发送请求并接收后端返回的数据,并根据需要进行展示或者修改。 第六步:前后端联调和测试 在开发过程中,前后端需要联调和测试,确保前端后端的功能可以正常配合使用和交互。 第七步:部署网站 完成开发和测试后,将前端代码和后端管理系统部署到服务器上。前端代码可以使用静态文件服务器进行部署后端管理系统可以使用Web服务器进行部署。 总结:搭建一个网站前端框架和后端管理系统需要确保两者之间的配合使用。前端负责页面的展示和交互,后端负责处理数据和逻辑。通过前后端的数据交互,实现网站的功能和需求。 ### 回答3: 搭建一个网站前端框架和后端管理系统,可以通过以下步骤进行: 1. 好规划和设计:首先确定网站的需求和功能,设计网站前端的用户界面和交互流程,以及后端管理系统的数据结构和交互方式。 2. 选择合适的前端框架:根据网站需求和设计,选择适合的前端框架,如React、Vue等,并搭建基本的项目结构。 3. 前端开发:根据设计稿和需求,进行前端页面的开发,包括页面布局、样式设计、交互逻辑等。使用HTML、CSS和JavaScript等技术进行页面的编写和交互实现。 4. 后端架构设计:根据网站需求,选择合适的后端技术栈,如Java、Python等,并设计后端管理系统的数据库结构和接口设计。 5. 后端开发:根据设计的数据库结构和接口设计,进行后端管理系统的开发。使用所选择的后端技术进行业务逻辑的实现、数据的处理和管理。 6. 前后端联调:前端开发完成后,与后端进行接口对接和交互,确保数据的传输和交互正常。针对接口调试中的问题进行修改和优化。 7. 测试和优化:进行系统整体的功能测试和性能测试,保证网站正常运行和用户体验。根据测试结果对系统进行优化和改进,提升性能和用户体验。 两者的配合使用可以通过接口进行数据的传递和交互。前端通过调用后端提供的接口,获取和提交数据,并展示在用户界面上。后端处理前端发送的请求,进行业务逻辑的处理和数据库操作,然后返回相应的数据给前端前端后端的配合需要保持接口的一致性和稳定性,确保数据的准确性和安全性。同时,与后端开发人员之间的良好沟通和密切合作也是保证系统顺利开发和运行的重要因素。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NoBug.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值