目录

一、spa项目完成登录注册布局

1、安装开发模块

2、引入main.js配置

3、登录注册页跳转

二、vue数据交互实现登录功能

引入main.js配置

三、ajax 跨域问题

1.引入main.js配置

2.跨域显现问题

3.解决方案

四、axios 的 get/post 的区别( qs )

1.引入main.js配置

2、解决方案

五、This 指针变量污染


一、spa项目完成登录注册布局

1、安装开发模块

在项目的根目录下cmd执行以下命令

npm install element-ui -S

npm install axios -S

npm install qs -S

npm install vue-axios -S

2、引入main.js配置

import Vue from 'vue'

import ElementUI from 'element-ui' // 新添加 1

import 'element-ui/lib/theme-chalk/index.css' // 新添加 2 ,避免后期打包样式不同,要放在import App from './App'; 之前

import App from './App'

import router from './router'

Vue.use(ElementUI)   // 新添加 3

Vue.config.productionTip = false

3、登录注册页跳转

Login.vue

<template><div><el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container"><el-row><el-col :span="24"><div style="text-align: center;" class="grid-content bg-purple-dark"><h3>用户登录</h3></div></el-col></el-row><el-form-item label="用户名" prop="uname"><el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input></el-form-item><el-form-item label="用户密码" 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 style="text-align: center;" class="grid-content bg-purple-dark"><el-button style="width: 100%;" type="primary" @click="submitForm">提交</el-button></div></el-col></el-row></el-form-item><el-form-item><el-row><el-col :span="12"><div class="grid-content bg-purple-dark"><el-link type="success" @click="Reg" >用户注册</el-link></div></el-col><el-col :span="12"><div class="grid-content bg-purple-dark"><el-link type="warning">忘记密码</el-link></div></el-col></el-row></el-form-item></el-form></div>
</template><script>export default {name: 'Login',data() {return {ruleForm: {}}}}
</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>

App.vue

<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>

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}]
})

跳转效果:

二、vue数据交互实现登录功能

引入main.js配置

import axios from '@/api/http'  #vue项目对axios的全局配置

import VueAxios from 'vue-axios'

Vue.use(VueAxios,axios)

Login.vue

<script>export default {name: 'Login',data() {return {ruleForm: {}}},methods: {submitForm(){//this.axios  找到的是/api/http.js文件//axios.urls = action 找到的是action.js//action.js是一个json对象   name就可以取到请求的值let url = this.axios.urls.SYSTEM_USER_DOLOGIN;// alert(url);this.axios.post(url,this.ruleForm).then(res =>{//代表成功   箭头函数 jdk8的语法console.log(res.data.result);if(res.data.code == 1){this.$message({message:res.data.msg,type:'success'});} else if(res.data.code == 0){this.$message.error(res.data.msg);}}).catch(function(){//代表失败});},Reg(){this.$router.push({path:'/Reg'})}}}
</script>

效果:

三、ajax 跨域问题

跨域产生的因素:协议、ip、端口、项目有任意一步发生改变,都会产生跨域

1.引入main.js配置

import axios from 'axios'

2.跨域显现问题

3.解决方案

后端工具类里添加  CorsFilter.java

package com.javaxl.util;import java.io.IOException;import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletResponse;/*** 配置tomcat允许跨域访问* * @author Administrator**/
public class CorsFilter implements Filter {@Overridepublic void init(FilterConfig filterConfig) throws ServletException {}@Overridepublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)throws IOException, ServletException {HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;// Access-Control-Allow-Origin就是我们需要设置的域名// Access-Control-Allow-Headers跨域允许包含的头。// Access-Control-Allow-Methods是允许的请求方式httpResponse.addHeader("Access-Control-Allow-Origin", "*");// *,任何域名httpResponse.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");filterChain.doFilter(servletRequest, servletResponse);}@Overridepublic void destroy() {}
}

四、axios 的 get/post 的区别( qs )

axios、qs的作用
api/http.js
1.将原生大的json对象转换为字符串,通过拦截器转换
2.将本项目中的所有的接口地址,进行统一管理

get/post的区别
    this.form
    {param:this.form}

1.引入main.js配置

import axios from 'axios'

Login.vue

this.axios.post(url, this.ruleForm).then(function(response) {console.log(response);}).catch(function(error) {console.log(error);});

现象:

2、解决方案

Login.vue

this.axios.post(url, qs.stringify(this.ruleForm)).then(function(response) {console.log(response);}).catch(function(error) {console.log(error);});

现象:

五、This 指针变量污染

现象:

解决:

this.axios.post(url,this.ruleForm)
        .then(res =>{//代表成功   箭头函数 jdk8的语法
          console.log(res.data.result);
          if(res.data.code == 1){
            this.$message({
              message:res.data.msg,
              type:'success'
            });
          } else if(res.data.code == 0){
            this.$message.error(res.data.msg);
          }
        }).catch(function(){//代表失败

});

spa项目开发(登录注册)相关推荐

  1. SPA项目之登录注册

    文章目录 创建项目 需要注意的问题 解析后台交互(axios/qs/vue-axios) 导入代码 关于后台拦截问题 创建项目 vue init webpack t224_spa cd t224_sp ...

  2. SPA项目开发 之 登录注册

    SPA项目开发 登录注册 数据库 后台代码 prox.xml 配置 web.xml 配置 CorsFilter HBuilder X api 目录 action.js http.js router 目 ...

  3. 快速上手Springboot项目(登录注册保姆级教程)

    本文章对SpringBoot开发后端项目结构做了简单介绍,并示范了使用SpringBoot+MySQL实现登录的后端功能,与本博客的另一篇文章 Vue 实现登录注册功能(前后端分离完整案例) | Ma ...

  4. java优化登录注册,Java-Web(项目)优化登录注册

    Java-Web(项目)优化登录注册 Java-Web(项目)优化登录注册 实现代码: package com.homework.dao1; public interface Login { publ ...

  5. Vue项目之登录注册

    Vue项目之登录注册 1. 注册 1.1 注册页面的布局 1.2 注册业务逻辑的实现 2. 登录 3.导航守卫 3.1全局导航守卫,全部路由都会经过这里.一定要调用next方法向下执行 3.2 路由独 ...

  6. javaweb开发的仿推特项目之登录注册功能

    博主最近学习一个仿推特javaweb项目,其采用Jsp+Servlet的方式进行设计,MySQL数据库,Tomcat8服务,界面上十分美观,功能也较为健全,给大家分享一下: 项目地址 登录界面: 核心 ...

  7. spa项目开发首页导航左侧菜单

    前言:今天要分享的知识是spa项目完成首页导航以及左侧菜单 码字不易,转载请说明!!! 目录 目标 效果图 一.mock.js ①什么是Mock.js ②安装mockjs依赖 ③配置开发环境及生产环境 ...

  8. Vue项目二 登录注册功能的实现

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一.系统注册功能的实现 1.配置注册页面路由 2.注册页面的搭建 3.api下发送ajax请求的文件创建 二.后台数据 ...

  9. EClass课堂项目(一)-登录注册

    登录注册功能实现 登录实现 LoginActivity(登录活动) (PS.因为是对前期项目的整理,因此含有部分其他代码,当时未学习注解使用,最好使用注解对View实现实例创建,以及对业务逻辑代码进行 ...

最新文章

  1. Python中的map()函数
  2. 深度对话林元庆:AI创业历史性窗口到来,将诞生下个BAT
  3. LeetCode 90子集Ⅱ91解码方法
  4. 友邦人寿引入阿里云PolarDB云数据库 支撑保险业务系统加速上云
  5. Objective-C method及相关方法分析
  6. java原子类场景,CAS你知道吗?原子类AtomicInteger的ABA问题谈谈?,原子共面问题...
  7. CookieHelper
  8. python for 格式化字符串 list.count
  9. 【教学类-10-02】20221025《空心图案4*2-不重复》( 随机图案拼贴)(大班主题《动物花花衣》)
  10. 新型智慧城市城市大脑大数据平台顶层设计规划建设方案
  11. 什么是实例?什么是引用?
  12. 静态路由配置全面详解,静态路由快速入门指南
  13. 记一次ARM-鲲鹏服务器读写parquet报错解决过程
  14. android8.0技术体系,安卓8.0剧透汇总:这样简洁流畅的系统,连iOS都怕了!
  15. 修改火狐浏览器滚动条样式
  16. NYOJ-20 吝啬的国度【深搜】
  17. 511遇见易语言计次循环首九九乘法表
  18. 医院AI智能随访电话机器人-北京联络加Loojion自主研发
  19. AutoCAD2012从入门到精通中文视频教程 第15课 图案填充(个人收藏)
  20. [JS]JS模拟Alert弹出框效果--自定义CSS样式

热门文章

  1. 几个非洲鼓的基本节奏
  2. python爬虫案例——东方财富股票数据采集
  3. iso sqlserver2012sp1_SQL Server 2008 R2升级到SQL Server 2012 SP1
  4. CS61B学习笔记——proj2 gitlet的实现
  5. UEFI调试网络启动-WINDOWS搭建PXE服务器
  6. java调用接口速度慢,Java 调用 webservice 接口,为什么这么慢
  7. 高品质混响延迟插件7个合集 – ValhallaDSP Plugins Bundle macOS
  8. 树莓派与STM32通信编码格式
  9. C# 多线程初级汇总
  10. Laravel框架 view视图