1、在view文件夹下创建login文件夹,创建index.vue:代表登录的组件

配置router.js,导入登录组件

import Vue from "vue";
import Router from "vue-router";
// 导入登录组件’
import Login from './views/login/index.vue' Vue.use(Router); export default new Router({
// mode: "history",
//base: process.env.BASE_URL,
routes: [
{
path: '/login',
name: 'login', //路由名称
component: Login //组件对象
} ]
});

2、结合Element-UI编写index.vue,index.vue的目录为:views/login/index.vue

<template>
<div class="login-container">
<bubbles-effect :options="options"></bubbles-effect>
<el-form ref="form" :model="form" label-width="80px" class="login-form">
<h2 class="login-title" style="center">后台管理系统登录</h2>
<el-form-item label="账号" class="box">
<el-input v-model="form.name"></el-input>
</el-form-item>
<el-form-item label="密码" class="box">
<el-input v-model="form.password" type="password"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">登录</el-button>
<el-button class="cancle">取消</el-button>
</el-form-item>
</el-form> </div> <!-- <vue-canvas-nest></!--> </template> <script>
import vueCanvasNest from "vue-canvas-nest";
// import bubblesEffect from 'vue-canvas-effect' export default {
data() {
return {
form: {
username: "",
password: ""
},
options: {
color: "rgba(225,225,225,0.5)", //Bubble color
radius: 15, //Bubble radius
densety: 0.3, // The larger the bubble density, the greater the density (suggest no more than 1).
clearOffset: 0.2 // The larger the bubble disappears [0-1], the longer it disappears.
}
};
},
components: {
vueCanvasNest
// bubblesEffect
},
methods: {
onSubmit() {
console.log("submit!");
}
}
};
</script> <style scoped>
.login-form {
width: 350px;
/* 上下嫌隙 160px,左右自动居中 */
margin: 160px auto;
background-color: rgb(255, 255, 255, 0.8);
padding: 28px;
border-radius: 20px;
/* border: solid 1px black; */
box-shadow: 0 0 30px 3px rgba(119,118,118,0.33);
} .login-container {
position: absolute;
width: 100%;
height: 100%;
} .login-title {
color: #303133;
text-align: center;
} .cancle {
margin-left: 80px;
} .box {
margin-left: 0px;
}
</style>

3、表单验证

  1、在el-form中导入 :rules="rules",el-form-item导入pro=“属性名称”

在export的data中配置rules:

 rules: {
username: [
{ required: true, message: '密码不能为空', trigger: 'blur' }
],
password: [
{ required: true, message: '密码不能为空', trigger: 'blur' }
]
},

配置methods:

methods: {
submitForm(formName) {
//定位到表单,再进行校验
this.$refs[formName].validate(valid => {
// console.log(valid) //成功为true,失败为false
if(valid){
// 提交表单给后台进行验证是否正确
}else{
console.log('验证失败')
return false
}
})
},
// onSubmit() {
// console.log("submit!");
// }
// }
}

4、easyMock添加系统登录后台服务接口

  1、修改.env.develoment文件中的目标服务接口地址---------VUE_APP_SERVICE_URL

  2、配置 Mock.js,创建新的接口

    ①当登录成功后,响应状态码2000和token值,token用来认证(后面请求只要是成功的,状态码均为2000,这个是与后台接口的约定)

  *  请求URL:/user/login

  *  请求方式:post

  *  描述: 登录认证

  *  mock.js 接口配置:

{
"code": 2000, //状态码
"flag": true,
"message": '验证成功',
"data": {
"token": "admin"
}
}

    ②通过token获取用户信息:

      添加响应用户信息模拟接口:

      *  请求URL:/user/info/{token}

      *  请求方式:get

      *  描述:响应用户信息

      *  mock.js 配置

{
"code": 2000,
"flag": true,
"message": '成功获取用户信息',
"data": {
"id|1-10000": 1,
"name": "@cname",
"roles": ["manager"]
}
}

5、登录逻辑实现

在src/api 下创建login.js,导出两个方法

import request from '@/utils/request'

// 导出函数
export function login(username, password) {
return request({
url: '/user/login',
method: 'post',
data: {
username, //username: username
password
}
})
} // 获取返回的用户信息
export function getUserInfo(token) {
return request({
url: `/user/info/${token}`,
method: 'get'
})
}

表单校验:

methods: {
submitForm(formName) {
//定位到表单,再进行校验
this.$refs[formName].validate(valid => {
// console.log(valid) //成功为true,失败为false
if(valid){
// 提交表单给后台进行验证是否正确,then后面传入回调函数
login(this.form.username,this.form.password).then(response => {
const resp = response.data
console.log(resp,resp.flag,resp.data.token)
if (resp.flag) {
// 当resp.flag为true时,表示验证成功
// 通过token获取用户信息
getUserInfo(resp.data.token).then(response => {
const respUser = response.data
console.log(respUser)
if (respUser.flag){
// 获取到用户的数据
//成功
console.log('userInfo',respUser.data)
// 1.保存token,用户信息
localStorage.setItem('msm-user', JSON.stringify(respUser.data))
localStorage.setItem('msm-token', resp.data.token)
// 前往首页
this.$router.push('/')
}else{
this.$message.error(respUser.message);
} })
}else {
// 未通过,弹出警告
this.$message.error(resp.message);
}
}) }else{
console.log('验证失败')
return false
}
})
},
// onSubmit() {
// console.log("submit!");
// }
// }
}

Vuejs实战项目:登陆页面的更多相关文章

  1. Vuejs实战项目四:权限校验

    路由跳转参考文档:https://router.vuejs.org/zh/guide/advanced/navigation-guards.html 在/src下创建permission.js进行权限 ...

  2. Vuejs实战项目步骤一

    1.使用vue初始化项目 vue create msm-demo #创建项目 npm run serve #部署 2.更改public文件夹下面的index文件,只留下 <div id=&quo ...

  3. Vuejs实战项目五:数据列表

    1.在EasyMock 中添加数据列表模拟接口 请求url:/suyuan/list 请求方式:get 描述:数据列表 mock.js配置: 例: { "code": 2000, ...

  4. Vuejs实战项目三:退出系统功能实现

    1.创建Mockjs接口 method:post url:/user/logout 描述:退出系统 response: { "code": 2000, //状态码 "fl ...

  5. SPA项目中,404页面 和 登陆页面 对应的路由,应该怎样控制?

    SPA项目中,404页面 和 登陆页面 对应的路由,应该怎样控制? 可以这样做: 登陆之前,所有页面跳到 登陆页面:包括随便输入的路由地址. 登陆后,跳到相应页面:随便输入的.不存在的路由地址,才跳到 ...

  6. 小KING教你做android项目(二)---实现登陆页面并跳转和简单的注册页面

    原文:http://blog.csdn.net/jkingcl/article/details/10989773       今天我们主要来介绍登陆页面的实现,主要讲解的就是涉及到的布局,以及简单的跳 ...

  7. 编写大型项目web页面 从写web登陆页面开始

    web页面搭建需要准备什么工具 首先我们会和设计师沟通 我们需要一些检验设计的工具 ps 自动裁图 自动测量工具 (我这里安利一下一个工具 我用的cutterman) sketch 可以使用阿里的工具 ...

  8. 前后端分离之vue2.0+webpack2 实战项目 -- webpack介绍

    webpack的一点介绍 Webpack 把任何一个文件都看成一个模块,模块间可以互相依赖(require or import),webpack 的功能是把相互依赖的文件打包在一起.webpack 本 ...

  9. vue+websocket+express+mongodb实战项目(实时聊天)

    继上一个项目用vuejs仿网易云音乐(实现听歌以及搜索功能)后,发现上一个项目单纯用vue的model管理十分混乱,然后我去看了看vuex,打算做一个项目练练手,又不想做一个重复的项目,这次我就放弃颜 ...

随机推荐

  1. Foundation框架系列-NSDictionary

    排序 对字典中的key按照字母升序排序 // NOTE: 排序,得出最终请求字串 NSArray* sortedKeyArray = [[tmpDict allKeys] sortedArrayUsi ...

  2. Halt- Linux必学的60个命令

    1.作用 halt命令的作用是关闭系统,它的使用权限是超级用户. 2.格式 halt [-n] [-w] [-d] [-f] [-i] [-p] 3.主要参数说明 -n:防止sync系统调用,它用在用 ...

  3. JS规则 我与你同在(逻辑与操作符)数学中的“b大于a,b小于c”是“a<b<c”,那么在JavaScript中可以用&&表示

    我与你同在(逻辑与操作符) 数学里面的"a>b",在JavaScript中还表示为a>b:数学中的"b大于a,b小于c"是"a<b& ...

  4. 通过ID获取元素 注:获取的元素是一个对象,如想对元素进行操作,我们要通过它的属性或方法。

    通过ID获取元素 学过HTML/CSS样式,都知道,网页由标签将信息组织起来,而标签的id属性值是唯一的,就像是每人有一个身份证号一样,只要通过身份证号就可以找到相对应的人.那么在网页中,我们通过id ...

  5. Struts2基本总结

    现在Struts2慢慢退出舞台了,但是很多项目还需要用Struts2进行开发和维护,这里就简单的重新快速的掌握这门技术 Struts2的相关配置文件 * default.properties     ...

  6. 满血复活前的记录(持续更新ing)

    时隔一年重新开启算法竞赛征程. 该记录大多为老课件.已经做过的习题重做和已经看过的书本重看 7.21 下午到山大 娄晨耀basic_algorithm课件中的内容: 复习线性筛原理 复习差分 做完Co ...

  7. Python全栈开发:线程、进程和协程

    Python线程 Threading用于提供线程相关的操作,线程是应用程序中工作的最小单元. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 #!/usr/bin/env pytho ...

  8. [转]C#多线程学习 之 线程池[ThreadPool]

    在多线程的程序中,经常会出现两种情况: 一种情况:   应用程序中,线程把大部分的时间花费在等待状态,等待某个事件发生,然后才能给予响应                   这一般使用ThreadPo ...

  9. 用shell编写小九九乘法表程序

    1.使用for循环 运行结果: 2.方法二:for循环 运行结果: 备注: 1. echo -n 的意思是不自动换行,因为在linux shell中 echo到最后一个字符时会自动换行的,所以echo ...

  10. ThinkPHP模型基础类提供的连贯操作方法

    ThinkPHP模型基础类提供的连贯操作方法(也有些框架称之为链式操作),可以有效的提高数据存取的代码清晰度和开发效率,并且支持所有的CURD操作. 直线电机哪家好 使用也比较简单, 假如我们现在要查 ...