catalogue
1, SPA project login registration layout
3, Pointer variable pollution of This
5, The difference between get/post of Axious
1, SPA project login registration layout
Clear effect: login registration interface effect:
1. During project layout, first install the required configurations and import all dependencies. Write the following four lines of statements line by line in the cmd of the project
npm install element-ui -S
npm install axios -S
npm install qs -S
npm install vue-axios -S
2. After completing the above operations, you can use the element UI for layout. Add the following statement to src/main.js
import ElementUI from 'element-ui' // New addition one
import 'element-ui/lib/theme-chalk/index.css' // New addition two , Avoid late packaging styles
3. In order to check whether your configuration is successful, install the components in Element to verify that if it works, the installation configuration is successful.
Helloword.Vue:
<template> <div class="hello"> <h1>{{ msg }}</h1> <h2>Essential Links</h2> <ul> <li> <a href="https://vuejs.org" target="_blank" > Core Docs </a> </li> <li> <a href="https://forum.vuejs.org" target="_blank" > Forum </a> </li> <li> <a href="https://chat.vuejs.org" target="_blank" > Community Chat </a> </li> <li> <a href="https://twitter.com/vuejs" target="_blank" > Twitter </a> </li> <br> <li> <a href="http://vuejs-templates.github.io/webpack/" target="_blank" > Docs for This Template </a> </li> </ul> <h2>Ecosystem</h2> <ul> <li> <a href="http://router.vuejs.org/" target="_blank" > vue-router </a> </li> <li> <a href="http://vuex.vuejs.org/" target="_blank" > vuex </a> </li> <li> <a href="http://vue-loader.vuejs.org/" target="_blank" > vue-loader </a> </li> <li> <a href="https://github.com/vuejs/awesome-vue" target="_blank" > awesome-vue </a> </li> </ul> </div> </template> <script> export default { name: 'HelloWorld', data () { return { msg: 'Welcome to Your Vue.js App' } } } </script> <!-- Add "scoped" attribute to limit CSS to this component only --> <style scoped> h1, h2 { font-weight: normal; } ul { list-style-type: none; padding: 0; } li { display: inline-block; margin: 0 10px; } a { color: #42b983; } </style>
The button effect indicates that the Element configuration is successfully installed.
4. Create a Vue with internal components, named Login.vue. Find the form code in Element, write it to Login.vue, and provide the components.
Login.Vue:
<template> <div id="app" class="login-wrap"> <h3 style="text-align: center;">User login</h3> <el-form :model="ruleForm" status-icon ref="ruleForm" class="demo-ruleForm login-container"> <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="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"> <el-button style="width: 100%;" type="primary" @click="submitForm('ruleForm')">Submit</el-button> </div> </el-col> </el-row> <el-row> <el-col :span="12"> <div class="grid-content bg-purple-dark"> <el-link type="success" @click="toReg">Registered user</el-link> </div> </el-col> <el-col :span="12"> <div class="grid-content bg-purple-dark"> <el-link type="warning">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: { toReg() { this.$router.push({ //Jump from one interface to another path: '/Reg' }); }, submitForm() { let url = this.axios.urls.SYSTEM_USER_DOLOGIN; this.axios.post(url, this.ruleForm).then((resp) => { //Code for front-end and back-end interaction 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> <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>
Note: in Login.Vue as like as two peas in the database, you should notice that the uname of prop should be exactly the same as the name in the database.
< El form item label = "account" prop = "uname" >
<el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
</el-form-item>
< El form item label = "password" prop = "PWD" >
<el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
</el-form-item>
Operation effect:
5. When I click register user, I want to jump to the user registration interface. Create a Reg.vue component and copy the Login content. Change the component name.
The registered user in Login.Vue writes a click event and a method to jump to the Login interface in script:
<script> export default { name: 'Login', data() { return { ruleForm: {} } }, methods: { toReg() { this.$router.push({ //Jump from one interface to another path: '/Reg' }); }, </script>
this.$router.push({/ / jump from one interface to another
path: '/Reg'
})
The same is true for jumping to the Login.vue component in reg.vue.
2, SPA project login function
Premise: import the maven project into eclipse, change the version of mysql in pom.xml, and connect to the contents in the database db.properties file.
db.properties:
1. To realize the login function, it is necessary to realize the front and rear data interaction.
Requirements: when you click Submit, you need to interact the data from the front end to the back end, and then access the database from the back end to check whether the user name and password are correct.
Meet the requirements: in the submission method of Login.Vue, first realize the data interaction between the front and back ends, then obtain the path to access the corresponding action, and then judge that if the returned data is 1, the user's login is successful, and if the returned data is 2, the login fails.
Login.Vue:
submitForm() {
let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
This. Axios. Post (URL, this. Ruleform). Then ((RESP) = > {/ / code for front-end and back-end interaction
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);
});
How to write the url: you need to view it from action.js and http.js
let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
http.js
action.js:
2. Login action in eclipse:
package com.zking.vue.web; import java.util.HashMap; import java.util.Map; import com.fasterxml.jackson.databind.ObjectMapper; import com.opensymphony.xwork2.ModelDriven; import com.zking.base.web.BaseAction; import com.zking.vue.biz.UserBiz; import com.zking.vue.entity.User; import com.zking.vue.util.JsonData; import com.zking.vue.util.JwtUtils; import com.zking.vue.util.PageBean; import com.zking.vue.util.ResponseUtil; import com.zking.vue.util.StringUtils; public class UserAction extends BaseAction implements ModelDriven<User>{ private UserBiz userBiz; private User user = new User(); public UserBiz getUserBiz() { return userBiz; } public void setUserBiz(UserBiz userBiz) { this.userBiz = userBiz; } public String login() { ObjectMapper om = new ObjectMapper(); JsonData jsonData = null; try { if(StringUtils.isBlank(user.getUname()) || StringUtils.isBlank(user.getPwd())) { jsonData = new JsonData(0, "User or password is empty", user); }else { User u = this.userBiz.login(user); // Map<String, Object> claims = new HashMap<String, Object>(); // claims.put("uname",user.getUname()); // claims.put("pwd", user.getPwd()); // String jwt = JwtUtils.createJwt(claims, JwtUtils.JWT_WEB_TTL); // response.setHeader(JwtUtils.JWT_HEADER_KEY, jwt); jsonData = new JsonData(1, "Login succeeded", u); } } catch (Exception e) { e.printStackTrace(); jsonData = new JsonData(0, "User or password error", user); }finally { try { ResponseUtil.write(response, om.writeValueAsString(jsonData)); } catch (Exception e) { e.printStackTrace(); } } return null; } public String getAsyncData() { ObjectMapper om = new ObjectMapper(); try { Thread.sleep(6000); ResponseUtil.write(response, om.writeValueAsString("http://www.javaxl.com")); } catch (Exception e) { e.printStackTrace(); } return null; } @Override public User getModel() { return user; } }
3, Data in database:
4, Login function effect display:
3, Pointer variable pollution of This
1. Why is This pointer variable polluted?
When a this is used in html, the value of this will not change, even if this is used later, because this scope is not available in axios.
2. Scenario reproduction:
code:
<script> submitForm() { let url = this.axios.urls.SYSTEM_USER_DOLOGIN; this.axios.post(url, this.ruleForm).then(function(resp) { //Code for front-end and back-end interaction 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>
effect:
3. Solution:
1. Define a variable outside and put the this pointer into the
2. Use arrow function
1. Define a variable outside and put the this pointer into the
<script> submitForm() { let url = this.axios.urls.SYSTEM_USER_DOLOGIN; let obj=this; this.axios.post(url, this.ruleForm).then((resp) => { //Code for front-end and back-end interaction console.log(resp); if (resp.data.code == 1) { obj.$message({ message: resp.data.msg, type: 'success' }); } else { this.$message({ message: resp.data.msg, type: 'warning' }); } }).catch(function(error) { console.log(error); }); </script>
2. Use arrow function
4, Ajax cross domain issues
1. There are four situations where ajax cross domain problems occur:
2. Solution:
In eclipse, there is a cors.filter file: any domain name can be placed in it. Four methods have been added, deleted, modified and checked
5, The difference between get/post of Axious
1. Explain the difference between get/post of Axious and the function of http.js:
Generally, there are two forms of data transfer to eclipse, the first is in the form of array and the other is in the form of string. However, the value accepted in eclipse is string.
No matter which dependency is used in src/main.js, it can be used
import axios from '@/api/http' //# Global configuration of Axios by vue project
// import axios from 'axios' //# Global configuration of Axios by vue project
You can use any value transfer method in Login.vue
// let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
character string:
Object:
However, when receiving the object, the value in eclipse is null, so the login will fail,
2. Solution:
2.1 the code for converting objects into strings has been written in http.js for a long time:
http.js:
//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; };
2.2 use qs's stringify() method in Login.vue to convert objects into strings:
The above two solutions are OK!
Today's knowledge is shared here. I hope it can help you!