catalogue
1: The spa project completes the login and registration layout
2. Introduce the main.js configuration (leading css and then JS)
Tests: adding elementUI Component view effect
3. src/views/Login.vue (login)
4. src/views/Reg.vue (registered)
2: Spa project completes the login function
2. Start front and rear data interaction
3: This Variable pollution caused by pointer
5: xios of get/post Differences between( qs )
1: The spa project completes the login and registration layout
1. Install development module
Enter NPM install element UI - S (install element UI)
npm install axios -S (plug-in for front and rear data interaction)
npm install qs -S (solve the difference between get/post of axios)
NPM install Vue Axios - S (for integration)
Note: ERR cannot appear during installation and download. If the installation of element UI fails, press the up key to re install
2. Introduce the main.js configuration (leading css and then JS)
import Vue from 'vue'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css' , Avoid different packaging styles in the later stage, and put them before import App from './App
import App from './App'
import router from './router'
Vue.use(ElementUI)
Vue.config.productionTip = false
Tests: adding elementUI Component view effect
<template> <div id="app"> <el-row> <el-button>Default button</el-button> <el-button type="primary">Main button</el-button> <el-button type="success">Success button</el-button> <el-button type="info">Information button</el-button> <el-button type="warning">Warning button</el-button> <el-button type="danger">Danger button</el-button> </el-row> <router-link to="/">home page</router-link> <router-link to="/Abort">about</router-link> <!-- The content displayed by the anchor depends on the component to which the route points--> <router-view/> </div> </template> <script> export default { name: 'App' } </script> <style> #app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
Display results
3. Login registration layout
First, learn new things from imitation
Components: public components
views: business component
1,src/App.vue
<template> <div id="app"> <router-view></router-view> </div> </template> <script> export default { name: 'App' } </script> <style> html, body { width: 100%; height: 100%; box-sizing: border-box; padding: 0px; margin: 0px; } #app { font-family: "Avenir", Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; color: #2c3e50; widows: 100%; height: 100%; } </style>
2,src/router/index.js
import Vue from 'vue' import Router from 'vue-router' import HelloWorld from '@/components/HelloWorld' import Login from '@/views/Login' import Reg from '@/views/Reg' Vue.use(Router) export default new Router({ routes: [{ path: '/', name: 'Login', component: Login }, { path: '/Login', name: 'Login', component: Login }, { path: '/Reg', name: 'Reg', component: Reg } ] })
3. src/views/Login.vue (login)
<template> <div id="app" class="login-wrap"> <el-form :model="ruleForm" status-icon ref="ruleForm" class="demo-ruleForm login-container "> <h3 style="text-align: center;">User login interface</h3> <el-form-item label="account number" prop="uname"> <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input> </el-form-item> <el-form-item label="Confirm password" prop="pwd"> <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input> </el-form-item> <el-form-item> <el-row> <el-col :span="24"> <div class="grid-content bg-purple-dark"></div> </el-col> <el-button style="width: 100%;" type="primary" @click="submitForm('ruleForm')">Submit</el-button> </el-row> <el-row> <el-col :span="12"> <div class="grid-content bg-purple-dark"></div> </el-col> <el-link type="primary" @click="toReg">User registration</el-link> <el-col :span="12"> <div class="grid-content bg-purple-dark"></div> </el-col> <el-link type="success">Forget password</el-link> </el-row> </el-form-item> </el-form> </div> </template> <script> export default { name: 'Login', data() { return { ruleForm: {} } }, methods: { toReg() { this.$router.push({ path: '/Reg' }); } } } </script> <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>
4. src/views/Reg.vue (registered)
<template> <div id="app" class="login-wrap"> <el-form :model="ruleForm" status-icon ref="ruleForm" class="demo-ruleForm login-container"> <h2 style="text-align: center;">User registration</h2> <el-form-item label="account number" prop="pass"> <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input> </el-form-item> <el-form-item label="password" prop="checkPass"> <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input> </el-form-item> <el-form-item label="Confirm password" prop="checkPass"> <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input> </el-form-item> <el-form-item> <el-row> <el-col :span="24"> <div class="grid-content bg-purple-dark"> <el-button style="width: 100%;" type="primary" @click="submitForm('ruleForm')">register</el-button> </div> </el-col> </el-row> <el-row> <el-col :span="12"> <div class="grid-content bg-purple-dark"> <el-link type="primary" @click="toLogin">User login</el-link> </div> </el-col> <el-col :span="12"> <div class="grid-content bg-purple-dark"> <el-link type="success">Forget password</el-link> </div> </el-col> </el-row> </el-form-item> </el-form> </div> </template> <script> export default { name: 'Login', data() { return { ruleForm: {} } }, methods:{ toLogin(){ this.$router.push({path:'/Login'}); } } } </script> <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>
Where: main code of page Jump:
< El link type = "primary" @ Click = "toreg" > user registration < / El link >
<script>
export default {
name: 'Login',
data() {
return {
ruleForm: {}
}
},
methods: {
toReg() {
this.$router.push({
path: '/Reg'
});
}
}
}
</script>
Operation results:
Register run results
2: Spa project completes the login function
1. Import an existing project
1. Open eclipse and click file - > Import.. - > existing Maven Projects - > broese to select your existing ready-made projects
2. The following instructions are successful when running
2. Start front and rear data interaction
1. Import Api folder to src
(1).action.js
/** * Encapsulation of the address requested by the background. The URL format is as follows: * Module name entity name operation */ export default { 'SERVER': 'http://localhost:8080/T216_SSH ', / / server 'SYSTEM_USER_DOLOGIN': '/vue/userAction_login.action', //User login 'SYSTEM_USER_DOREG': '/vue/userAction_reg.action', //User registration 'SYSTEM_MENU_TREE': '/vue/treeNodeAction.action', //Left tree menu loading 'SYSTEM_ARTICLE_LIST': '/vue/articleAction_list.action', //Article list 'SYSTEM_ARTICLE_ADD': '/vue/articleAction_add.action', //Article addition 'SYSTEM_ARTICLE_EDIT': '/vue/articleAction_edit.action', //Article modification 'SYSTEM_ARTICLE_DEL': '/vue/articleAction_del.action', //Article deletion 'SYSTEM_USER_GETASYNCDATA': '/vue/userAction_getAsyncData.action', //Asynchronous loading data in vuex 'getFullPath': k => { //Obtain the full address of the request for use in mockjs testing return this.SERVER + this[k]; } }
/** * vue Project global configuration for axios */ import axios from 'axios' import qs from 'qs' //The action module is introduced and added to the class attribute urls of axios import action from '@/api/action' axios.urls = action // axios default configuration axios.defaults.timeout = 10000; // Timeout // axios.defaults.baseURL = 'http://localhost:8080/j2ee15 '; / / default address axios.defaults.baseURL = action.SERVER; //Organize data // Only applicable to POST,PUT,PATCH, transformRequest ` allows you to modify the request data before sending it to the server axios.defaults.transformRequest = function(data) { data = qs.stringify(data); return data; }; // request interceptor axios.interceptors.request.use(function(config) { // var jwt = window.vm.$store.getters.getJwt; // config.headers['jwt'] = jwt; return config; }, function(error) { return Promise.reject(error); }); // Response interceptor axios.interceptors.response.use(function(response) { // debugger; // var jwt = response.headers['jwt']; // if(jwt){ // window.vm.$store.commit('setJwt',{jwt:jwt}); // } return response; }, function(error) { return Promise.reject(error); }); // //Route request interception // //http request interceptor // axios.interceptors.request.use( // config => { // //config.data = JSON.stringify(config.data); // //config.headers['Content-Type'] = 'application/json;charset=UTF-8'; // //config.headers['Token'] = 'abcxyz'; // //Judge whether there is a ticket. If so, add a ticket to each http header // // if (cookie.get("token")) { // // // The user sets the cookie to 2 hours for each operation // // cookie.set("token", cookie.get("token"), 1 / 12) // // cookie.set("name", cookie.get("name"), 1 / 12) // // config.headers.token = cookie.get("token"); // // config.headers.name = cookie.get("name"); // // } // return config; // }, // error => { // return Promise.reject(error.response); // }); // //Route response interception // //http response interceptor // axios.interceptors.response.use( // response => { // if (response.data.resultCode == "404") { // console.log("response.data.resultCode is 404") // //Return error code - 1, clear the ticket information and jump to the login page // // cookie.del("ticket") // // window.location.href='http://login.com' // return // } else { // return response; // } // }, // error => { // return Promise.reject(error.response) / / returns the error information returned by the interface // }); export default axios;
2. Introduce the main.js configuration (newly added)
import axios from '@/api/http' # Global configuration of Axios by vue project
import VueAxios from 'vue-axios'
Vue.use(VueAxios,axios)
(3).main.js
// The Vue build version to load with the `import` command // (runtime-only or standalone) has been set in webpack.base.conf with an alias. import Vue from 'vue' import 'element-ui/lib/theme-chalk/index.css' // Add 2 to avoid later packaging style import App from './App' import router from './router' import ElementUI from 'element-ui' // Add new 1 import axios from '@/api/http' // #Global configuration of axios by vue project import VueAxios from 'vue-axios' Vue.use(ElementUI) // Add new 3 Vue.use(VueAxios,axios) Vue.config.productionTip = false /* eslint-disable no-new */ new Vue({ el: '#app', router, components: { App }, template: '<App/>' })
3.src/views/Login.vue
<template> <div id="app" class="login-wrap"> <el-form :model="ruleForm" status-icon ref="ruleForm" class="demo-ruleForm login-container "> <h3 style="text-align: center;">User login interface</h3> <el-form-item label="account number" prop="uname"> <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input> </el-form-item> <el-form-item label="Confirm password" prop="pwd"> <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input> </el-form-item> <el-form-item> <el-row> <el-col :span="24"> <div class="grid-content bg-purple-dark"></div> </el-col> <el-button style="width: 100%;" type="primary" @click="submitForm">Submit</el-button> </el-row> <el-row> <el-col :span="12"> <div class="grid-content bg-purple-dark"></div> </el-col> <el-link type="primary" @click="toReg">User registration</el-link> <el-col :span="12"> <div class="grid-content bg-purple-dark"></div> </el-col> <el-link type="success">Forget password</el-link> </el-row> </el-form-item> </el-form> </div> </template> <script> export default { name: 'Login', data() { return { ruleForm: {} } }, methods: { toReg() { this.$router.push({ path: '/Reg' }); }, submitForm() { //$.ajax({url,scuc}) let url = this.axios.urls.SYSTEM_USER_DOLOGIN; /* Request background post (address, parameter, return)*/ this.axios.post(url,this.ruleForm).then(function(resp){ console.log(resp) }).catch(function(error){ console.log(error) }); } } } </script> <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>
(1) Main code:
submitForm() {
//$.ajax({url,scuc})
let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
/* Request background Post (address, parameter, return)*/
this.axios.post(url,this.ruleForm).then(function(resp){
console.log(resp)
}).catch(function(error){
console.log(error)
});
}
(2) Running result: (login succeeded)
(2.2) login failure (because there is no such user in my database)
3: This Variable pollution caused by pointer
1. Add message prompt
1,src/views/Login.vue
<script> export default { name: 'Login', data() { return { ruleForm: {} } }, methods: { toReg() { this.$router.push({ path: '/Reg' }); }, submitForm() { //$.ajax({url,scuc}) let url = this.axios.urls.SYSTEM_USER_DOLOGIN; /* Request background post (address, parameter, return)*/ //this refers to the vue instance this.axios.post(url,this.ruleForm).then(function(resp){ console.log(resp); //this refers to axios. There is no message method this.$message({ message: "Congratulations on your successful login", type: 'success' }); }).catch(function(error){ console.log(error) }); } } } </script> <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>
As follows: (indicates that the attribute cannot be read)
Solution: 1. Save the above this
submitForm() { //$.ajax({url,scuc}) let url = this.axios.urls.SYSTEM_USER_DOLOGIN; /* Request background post (address, parameter, return)*/ let obj=this; this.axios.post(url,this.ruleForm).then(function(resp){ console.log(resp); obj.$message({ message: "Congratulations on your success", type: 'success' }); }).catch(function(error){ console.log(error) }); }
Operation results
However, if many layers are nested, it is not advisable. Therefore, there is a second solution:
2. Solving the pollution problem of this pointer with arrow function
submitForm() { //$.ajax({url,scuc}) let url = this.axios.urls.SYSTEM_USER_DOLOGIN; /* Request background post (address, parameter, return)*/ this.axios.post(url,this.ruleForm).then((resp)=>{ console.log(resp); this.$message({ message: "Congratulations on your success. That's great", type: 'success' }); }).catch(function(error){ console.log(error) }); }
2. Perfect login
submitForm() { //$.ajax({url,scuc}) let url = this.axios.urls.SYSTEM_USER_DOLOGIN; /* Request background Post (address, parameter, return)*/ this.axios.post(url, this.ruleForm).then((resp) => { console.log(resp); if (resp.data.code == 1) { this.$message({ message: resp.data.msg, type: 'success' }); } else { this.$message({ message: resp.data.msg, type: 'warning' }); } }).catch(function(error) { console.log(error) }); }
Running result (login successful)
Login failed
4: ajax Cross domain problem
1. Comment out web.xml in eclipse To solve the cross domain problem of CORS, the filter will report the following errors (any CORS in the error is Cross domain issues)
1. Causes of cross domain
Protocol + IP+port + Project
Reasons for cross domain: one of the above four is different, which will occur
2.web.xml
<!-- solve cors Cross domain problem filter --> <filter> <filter-name>corsFilter</filter-name> <filter-class>com.zking.vue.util.CorsFilter</filter-class> </filter> <filter-mapping> <filter-name>corsFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
5: xios of get/post Differences between( qs )
1. axios original writing
main.js
import Vue from 'vue'
Import 'element UI / lib / theme talk / index. CSS' / / add 2 to avoid later packaging style
import App from './App'
import router from './router'
Import elementui from 'element UI' / / add 1
//import axios from '@/api/http' // #vue project global configuration of axios
import axios from 'axios'
import VueAxios from 'vue-axios'
login.vue
methods: {
toReg() {
this.$router.push({
path: '/Reg'
});
},
submitForm() {
//$.ajax({url,scuc})
//let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
// The original writing method is directly dead
let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
/* Request background Post (address, parameter, return)*/
this.axios.post(url, this.ruleForm).then((resp) => {
console.log(resp);
if (resp.data.code == 1) {
this.$message({
message: resp.data.msg,
type: 'success'
});
} else {
this.$message({
message: resp.data.msg,
type: 'warning'
});
}
}).catch(function(error) {
console.log(error)
});
}
}
What passed is the object
2.import axios from '@/api/http' Writing method
main.js
import Vue from 'vue'
Import 'element UI / lib / theme talk / index. CSS' / / add 2 to avoid later packaging style
import App from './App'
import router from './router'
Import elementui from 'element UI' / / add 1
import axios from '@/api/http' // #vue project global configuration of axios
//import axios from 'axios'
import VueAxios from 'vue-axios'
login.vue
submitForm() {
//$.ajax({url,scuc})
let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
// let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
/* Request background Post (address, parameter, return)*/
this.axios.post(url, this.ruleForm).then((resp) => {
console.log(resp);
if (resp.data.code == 1) {
this.$message({
message: resp.data.msg,
type: 'success'
});
} else {
this.$message({
message: resp.data.msg,
type: 'warning'
});
}
}).catch(function(error) {
console.log(error)
});
}
String passed
2. Influence
① . axios original writing
(1) The object passed is not available in the background
(2) Workaround (convert object to string) stringify())
login.vue
<script>
import qs from 'qs'
export default {
export default {
name: 'Login',
data() {
return {
ruleForm: {}
}
},
methods: {
toReg() {
this.$router.push({
path: '/Reg'
});
},
submitForm() {
//$.ajax({url,scuc})
// let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
/* Request background Post (address, parameter, return)*/
this.axios.post(url, qs.stringify(this.ruleForm)).then((resp) => {
console.log(resp);
if (resp.data.code == 1) {
this.$message({
message: resp.data.msg,
type: 'success'
});
} else {
this.$message({
message: resp.data.msg,
type: 'warning'
});
}
}).catch(function(error) {
console.log(error)
});
}
}
}
</script>