最近在做一个关于盲文打印机的项目,需要给app开发一个后台管理系统。目前基本功能已经实现,前前后后大概三天左右,后续还会继续添加功能、优化系统。
目前使用的技术栈:vue3、js、springboot、MP
此次开发使用了Fantastic-admin 管理系统框架基础版。一款优秀的框架会极大提高开发效率!
基础版免费,专业版也只有几百块、功能十分强大!有能力有需要的可以直接上专业版。
Fantastic - admin 管理系统框架下载、使用可以看我之前发的文章安利一个非常优秀的开源后台管理系统项目,开箱即用,极大提高效率
https://blog.csdn.net/qq_61672548/article/details/125719446?spm=1001.2014.3001.5501
Fantastic - admin 官网: Fantastic-admin | 一款 Vue 中后台管理系统框架一款开箱即用的 Vue 中后台管理系统框架,采用 Vue3 + Vite2 技术栈。https://hooray.gitee.io/fantastic-admin/?from=element-plus


这里设定了两种身份,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
login(@RequestBody BackstageUser user) { - LambdaQueryWrapper
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'
- })
- }
- })
-
- }
- })
- }
-
- }
.head:hover {
transform: translateY(-2px) scale(1.01);
box-shadow: 0 14px 24px rgb(0 0 0 / 20%);
border-radius: 10px;
}

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


https://blog.csdn.net/qq_61672548/article/details/125746240?spm=1001.2014.3001.5501

