七天从0到1基于vue实现docker管理平台之第1天

 

从本期文章开始,我将带大家从0开始基于前端vue框架实现一个docker管理平台。因为我是后端开发出身,对于前端技术完全是零基础,所以本次边做边学习,完成任务的同时,提高自己的技术能力!

第一天,我们的主要任务是搭建开发环境,并实现登录界面以及完成登录功能,并返回token!搭建环境的过程不再赘述,感兴趣的朋友可以自行网上搜索教程,我们直接上代码,实现登录功能!

首先展示下完整的工程结构:

 main.js核心文件的代码如下:

import ElementUI from 'element-ui' //新添加1
import 'element-ui/lib/theme-chalk/index.css' //新添加2,避免后期打包样式不同,要放在import App from './App';之前
import Vue from 'vue'
import App from './App'
import router from './router'

Vue.use(ElementUI)   //新添加3
Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})

router目录下的index.js文件内容:

import Vue from 'vue'
import Router from 'vue-router'
import Login from '@/components/Login'

Vue.use(Router)

const router = new Router({
  routes: [
    {
      path: '/',
      redirect: '/home'
    },
    {
      path: '/login',
      name: 'Login',
      component: Login
    }
  ]
})

export default router;

接着实现登录组件Login.vue:

<template>
  <div class="login-wrap">
    <el-form class="login-container">
      <h1 class="title">docker镜像管理平台</h1>
      <el-form-item label="账号">
        <el-input v-model="uname" placeholder="请输入账号"></el-input>
      </el-form-item>
      <el-form-item label="登录密码">
        <el-input placeholder="请输入密码" v-model="password" show-password></el-input>
      </el-form-item>

      <el-form-item>
        <el-button type="primary" style="width: 100%;" @click="dosubmit()">登录</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>
 
<script>
import axiosService from '@/utils/intercept';
import qs from 'qs';
export default {
  name: 'login',
  data: function () {
    return {
      uname: '',
      password: '',
      token: ''
    }
  },
  methods: {
    dosubmit: function () {
      let _this = this;
      if (this.uname === '' || this.password === '') {
        alert('用户名或密码不能为空');
      } else {
        let params = {
          uname: this.uname,
          password: this.password
        };
        var url = "http://localhost:8088/web/login";
        var str = qs.stringify(params);
        axiosService.post(url, str)
          .then(res => {
            console.log(res);
            console.log(_this);
            _this.token = res.data
          }).catch(function (error) {
            console.log(error);
          });
      }
    }
  }
}
</script>
 
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.login-wrap {
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  padding-top: 10%;
  background-image: url();
  /* background-color: #112346; */
  background-repeat: no-repeat;
  background-position: center right;
  background-size: 100%;
}

.login-container {
  border-radius: 10px;
  margin: 0px auto;
  width: 350px;
  padding: 30px 35px 15px 35px;
  background: #fff;
  border: 1px solid #eaeaea;
  text-align: left;
  box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
}

.title {
  margin: 0px auto 40px auto;
  text-align: center;
  color: #505458;
}
</style>

后端为了配合调试,我们临时搭建了一个Java工程(后续再使用golang替代),登录接口实现如下:

@RestController
@RequestMapping("web")
@Slf4j
public class PluginController {
    private static final String token = "123456789abc";

    @PostMapping(value = "/login", produces = "application/x-www-form-urlencoded;charset=UTF-8")
    public String login(String uname, String password){
        log.info("用户名:{},密码:{}", uname, password);
        if("admin".equals(uname)&&"123456".equals(password)){
            return token;
        }
        return "登录失败";
    }

}

然后我们启动工程:cnpm run dev

 启动成功,展示页面如下:

 点击登录按钮后,请求登录接口,完成登录操作!

到此为止,我们第一天的工作基本完成!实现了最基本的登录功能,并结合使用了vue的组件及路由功能。下一篇文章,我们的目标是实现页面跳转,并且实现将token保存的localStorage中,并且实现将token设置到http请求的header中。

希望大家多多关注,一起学习! 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue后台管理系统项目从0到1,可以按照以下步骤进行: 1. 创建项目:首先,使用Vue CLI工具创建一个新的Vue项目。可以使用命令行或图形界面工具来完成这一步骤。 2. 设计界面:根据需求,设计后台管理系统的界面。可以使用UI组件库(如Element UI、Ant Design Vue等)来加快开发速度。 3. 路由配置:使用Vue Router来配置路由,定义页面之间的跳转关系。可以根据后台管理系统的功能模块进行划分,设计合理的路由结构。 4. 数据管理:使用Vuex来管理全局的状态和数据。可以定义各个模块的状态、获取数据的方法,并在组件中使用。 5. 接口调用:根据后台管理系统与后端API的交互需求,使用Axios或其他HTTP请求库来发送请求并处理响应数据。 6. 功能开发:根据需求逐步开发各个功能模块。可以按照模块划分,分别开发不同的页面和组件。 7. 数据展示:根据后台管理系统的需求,使用Vue组件来展示数据,例如表格、图表等。可以使用第三方库来提供更多扩展功能。 8. 权限控制:根据需求,实现后台管理系统的权限控制功能。可以使用路由守卫、角色权限配置等方式来限制用户的操作权限。 9. 测试和调试:完成功能开发后,进行测试和调试,确保后台管理系统的稳定性和可靠性。 10. 打包部署:最后,使用Vue CLI提供的打包命令,将项目打包为静态文件,并部署到服务器上。 通过以上步骤,你可以从零开始构建一个Vue后台管理系统项目。当然,在实际开发中还会遇到各种具体问题和挑战,需要根据具体情况进行解决。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值