1. vue怎么引入和配置使用element-ui框架
1.1 使用vue-cli脚手架工具创建一个vue项目
vue init webpack pro01
1.2 npm安装elementUI
cd pro01 #进入新建项目的根目录
npm install element-ui -S #安装element-ui模块
1.3 在项目中src目录下找到main.js,并在指定位置添加三行代码(main.js是入口文件,所以在这里引入就行,页面就不用引入了)
2,创建登录注册页面,更改样式
3. 后台交互(axios/qs/vue-axios)
3.1 axios
axios是vue2提倡使用的轻量版的ajax。它是基于promise的HTTP库。它会从浏览器中创建XMLHttpRequests,与Vue配合使用非常好。
3.2 导入axios

然后重新启动项目(npm run dev)
把axios导入登录页面中

定义请求路径和参数


2.GET提交
axios.get('/user', {//注意数据是保存到json对象的params属性
params: {
ID: 12345
}
}).then(function (response) {
console.log(response);
}).catch(function (error) {
console.log(error);
});
3.POST提交
axios.post('/user', {//注意数据是直接保存到json对象
firstName: 'Fred',
lastName: 'Flintstone'
}).then(function (response) {
console.log(response);
}).catch(function (error) {
console.log(error);
});
注1:axios跨域问题,因为使用了前后端分离开发,跨域访问了,解决方案:需要配置tomcat允许跨域访问,
tomcat跨域配置方法很多,但最简单的方式是自己写一个过滤器CorsFilter实现,添加一个响应头

GET提交



设置提示框


注2:axios.get提交没有问题,axios.post提交后台接收不到数据
因为POST提交的参数的格式是Request Payload,这样后台取不到数据的,解决方案:使用qs.js库,将{a:'b',c:'d'}转换成'a=b&c=d'
POST提交

下载qs进行参数转换
导入qs

将参数进行转换

拼接式
简化axios/qs/vue-axios安装及使用步骤

复制两个请求地址

2.修改main.js文件
import axios from '@/api/http' #vue项目对axios的全局配置
mport VueAxios from 'vue-axios'
Vue.use(VueAxios,axios)
login就可以不用引入了

简化后的POST

也是可以的

简化后的GET

可以查看请求方式
<template>
<div class="login-wrap">
<el-form class="login-container">
<h1 class="title">用户登录</h1>
<el-form-item>
<el-input type="text" placeholder="用户账号" v-model="username" autocomplete="off"></el-input>
</el-form-item>
<el-form-item>
<el-input type="password" placeholder="用户密码" v-model="password" autocomplete="off"></el-input>
</el-form-item>
<el-button type="primary" @click="doLogin" style="width: 100%;">登录</el-button>
</el-form-item>
<el-row style="text-align: center;margin-top: 5px;">
<el-link type="primary" @click="toRegister">注册</el-link>
<el-link type="primary">忘记密码</el-link>
</el-row>
</el-form>
</div>
</template>
<script>
/* import axios from 'axios'
import qs from 'qs' */
export default {
name:'Login',
data:function(){
return {
username:'',
password:''
}
},
methods: {
doLogin:function(){
let username=this.username;
let password=this.password;
console.log("username=%s,password=%s",username,password);
//定义请求路径
let url=this.axios.urls.SYSTEM_USER_DOLOGIN; // /userAction.action
//定义请求参数
let params={
username:username,
password:password,
methodName:'userLogin'
}
console.log(params);
//发起ajax请求-GET(注意参数必须保存到params属性中)
this.axios.get(url,{params:params}).then(resp=>{
console.log(resp);
let data=resp.data;
console.log(data);
this.$message({
message: data.msg,
type: data.code==1?'success':'error'
});
}).catch(err=>{
console.log(err);
});
//发起ajax请求-POST
//payload:{a:'zs','b':'123'} ---> a=zs&b=123
/* let str=qs.stringify(params);
console.log(str); */
/* this.axios.post(url,params).then(resp=>{
console.log(resp);
}).catch(err=>{
console.log(err);
});*/
},
toRegister:function(){
this.$router.push('/Register');
}
}
}
</script>
<style>
.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>
连接数据库登录
1,写一个登录方法

package com.zking.vue.dao;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import com.zking.vue.entity.User;
import com.zking.vue.util.CommonUtils;
public class UserDao extends BaseDao{
public User userLogin(User user) {
String sql="select * from t_user_vue where username='"+user.getUsername()+"' and password='"+user.getPassword()+"'";
System.out.println(sql);
@SuppressWarnings("unchecked")
List<User> lst=super.executeQuery(sql, null, new CallBack<User>() {
@Override
public List<User> forEach(ResultSet rs) throws SQLException {
return CommonUtils.toList(rs, User.class);
}
});
if(lst!=null&&lst.size()!=0)
return lst.get(0);
else
return null;
}
}
2,调用方法

package com.zking.vue.action;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.zking.mvc.framework.DispatcherAction;
import com.zking.mvc.framework.ModelDriver;
import com.zking.vue.dao.UserDao;
import com.zking.vue.entity.User;
public class UserAction extends DispatcherAction implements ModelDriver<User> {
private User user=new User();
private UserDao userDao=new UserDao();
private ObjectMapper mapper=new ObjectMapper();
@Override
public User getModel() {
return user;
}
public String userLogin(HttpServletRequest req,HttpServletResponse resp)
throws ServletException,IOException{
Map<String,Object> json=new HashMap<String,Object>();
User us=userDao.userLogin(user);
if(us!=null) {
json.put("code","1");
json.put("msg", "用户登录成功");
}else {
json.put("code", "-1");
json.put("msg", "用户名或密码错误");
}
mapper.writeValue(resp.getOutputStream(),json);
return null;
}
}
本文介绍了如何使用Vue.js结合ElementUI框架搭建注册和登录页面,详细阐述了Vue项目中引入和配置ElementUI的步骤,以及如何通过axios进行后台交互。在axios的使用中,讨论了跨域问题的解决方法,并引入qs库处理POST请求的数据格式问题,以确保后台能够正确接收数据。最后展示了简化后的axios和vue-axios配置,以及登录功能的实现方法。
4万+

被折叠的 条评论
为什么被折叠?



