从本期文章开始,我将带大家从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中。

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

Logo

前往低代码交流专区

更多推荐