• Vue之ElementUI实现登陆及注册


    目录

    ​编辑

    前言

    一、ElementUI简介

    1. 什么是ElementUI

    2. 使用ElementUI的优势

    3. ElementUI的应用场景

    二、登陆注册前端界面开发

    1. 修改端口号

    2. 下载ElementUI所需的js依赖

    2.1 添加Element-UI模块

    2.2 导入Element-UI模块

     2.3 测试Element-UI是否能用

    3.编写登陆与注册界面

    3.1 创建组件

    3.2 将创建好的组件配置到路由中

    3.3 将App.vue的style覆盖

    3.5页面展示效果

    三、编写实现功能

    1. IDEA中导入项目

     2. 安装axio依赖及导入

    3.UserController控制器

    4.action.js配置

    5. 设置点击事件实现前后端交互

     Login.vue

     Register.vue

    页码效果演示

     四、跨域问题

     解决方案:


    前言

            在上一期的博客中我给各位老铁带来了有关Vue之vue-cli搭建SPA项目,上期的博客就是为本期博客做铺垫。今天我给老铁们带来有关ElementUI实现登陆及注册的案例实现模拟。

    一、ElementUI简介

    1. 什么是ElementUI

            ElementUI 是一个基于 Vue.js 的前端 UI 框架。它提供了丰富的可复用组件,使开发者可以快速构建现代化的 Web 应用程序界面。ElementUI 的组件库包括按钮、输入框、表格、弹窗、导航菜单等常用组件,同时还提供了一些高级组件如日期选择器、时间选择器、下拉框等。ElementUI 具有高度的定制性和扩展性,开发者可以根据自己的需求进行定制和拓展。它的简洁美观的设计风格得到了广大开发者的喜爱,广泛应用于各种 Web 项目中。

    2. 使用ElementUI的优势

    运用ElementUI的优势
    优势说明
    丰富的组件库ElementUI 提供了大量常用的组件,例如按钮、表单、表格、弹窗等,这些组件可以快速构建出现代化的用户界面。
    响应式布局ElementUI 的组件都支持响应式布局,能够适应不同设备的屏幕尺寸。这使得开发者可以轻松地实现移动端和桌面端的适配。
    简洁美观的设计ElementUI 遵循现代化的设计原则,采用扁平化风格和细致的交互细节,使得用户界面看起来美观、舒适。
    定制性和扩展性ElementUI 提供了丰富的定制选项和插槽机制,开发者可以根据自己的需求对组件进行个性化定制,也可以扩展组件功能。
    良好的文档和社区支持ElementUI 提供了详细的文档和示例代码,开发者可以轻松上手并解决问题。此外,ElementUI 拥有活跃的社区,开发者可以在社区中获得帮助、分享经验。

    3. ElementUI的应用场景

    ElementUI 可以应用于各种 Web 开发项目场景,包括但不限于以下几个方面:

    1. 后台管理系统:ElementUI 提供丰富的组件库和布局系统,非常适合构建后台管理系统。开发者可以利用 ElementUI 的表格、表单、弹窗等组件,快速构建出功能完善、美观易用的后台界面。

    2. 数据可视化应用:ElementUI 的数据展示组件如图表、进度条等,以及布局组件可以帮助开发者构建数据可视化的界面。开发者可以利用 ElementUI 提供的图表组件,实现数据的可视化展示和交互。

    3. 前端项目快速原型开发:ElementUI 的组件丰富而易用,适合用于快速原型开发。对于需要快速实现界面展示和交互的项目,可以选择使用 ElementUI 来快速搭建界面原型,并在后续迭代中进行调整和优化。

    4. 移动端应用开发:ElementUI 配合 Vue.js 的特性,可以很好地支持移动端应用开发。通过响应式布局和移动端适配,开发者可以使用 ElementUI 快速搭建适配移动端的用户界面。

    二、登陆注册前端界面开发

    我们先将之前创建的SPA项目还原成新建成后的样子,方便我们进行登陆注册前端界面开发。

    1. 修改端口号

    在我们编写前后端代码的时候,我们要确保前后端代码的端口号不能一致。在config文件下的index.js文件中修改port的属性值。

    2. 下载ElementUI所需的js依赖

            ElementUI下载的依赖分一下几种

    npm install 

            -g/ 将依赖下载到node_global全局依赖

            -d 下载依赖到SPA工程中,不会参与打包

            -s 下载依赖到SPA工程中,会参与打包

    我们使用的如果是-s的命令的话则会在static文件下的package.json文件中的depedencies中显示;如果是-s的命令的话则会在static文件下的package.json文件中的devDepedencies中显示。

    注:下载依赖最好终止项目运行。

    2.1 添加Element-UI模块

    执行命令:

    npm install element-ui -S

     可在项目中可以查看到是否成功添加

    2.2 导入Element-UI模块

    在src下的router文件中的main.js文件中导入Element-UI模块及样式,代码放在/App上面,代码如下

    1. // 新添加1
    2. import ElementUI from 'element-ui'
    3. // 新添加2,避免后期打包样式不同,要放在import App from './App';之前
    4. import 'element-ui/lib/theme-chalk/index.css'
    5. Vue.use(ElementUI);

     2.3 测试Element-UI是否能用

            我们去Element-UI官网去找几个组件方到App.vue中测试开是否效果。

    官网地址:Element - 网站快速成型工具

     

    1. <el-button>默认按钮el-button>
    2. <el-button type="primary">主要按钮el-button>
    3. <el-button type="success">成功按钮el-button>
    4. <el-button type="info">信息按钮el-button>
    5. <el-button type="warning">警告按钮el-button>
    6. <el-button type="danger">危险按钮el-button>

     

    效果演示 

    说明成功导入并使用成功。

    3.编写登陆与注册界面

    在src的目录创建一个views文件夹用来存放组件,然后在创建登陆与注册的组件。将App.vue的内容注释。

    3.1 创建组件

    Login.vue

    1. <template>
    2. <div class="login">
    3. <template>
    4. <div class="login-wrap">
    5. <el-form class="login-container">
    6. <h1 class="title">君易官网登录h1>
    7. <el-form-item label="">
    8. <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off">el-input>
    9. el-form-item>
    10. <el-form-item label="">
    11. <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off">el-input>
    12. el-form-item>
    13. <el-form-item>
    14. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交el-button>
    15. el-form-item>
    16. <el-row style="text-align: center;margin-top:-10px">
    17. <el-link type="primary">忘记密码el-link>
    18. <el-link type="primary" @click="gotoRegister()">用户注册el-link>
    19. el-row>
    20. el-form>
    21. div>
    22. template>
    23. div>
    24. template>
    25. <script>
    26. export default {
    27. name: 'Login',
    28. data () {
    29. return {
    30. msg: 'Welcome to Your Vue.js App',
    31. username:'',
    32. password:''
    33. }
    34. }
    35. }
    36. script>
    37. <style scoped>
    38. .login-wrap {
    39. box-sizing: border-box;
    40. width: 100%;
    41. height: 100%;
    42. padding-top: 10%;
    43. background-image: url();
    44. /* background-color: #112346; */
    45. background-repeat: no-repeat;
    46. background-position: center right;
    47. background-size: 100%;
    48. }
    49. .login-container {
    50. border-radius: 10px;
    51. margin: 0px auto;
    52. width: 350px;
    53. padding: 30px 35px 15px 35px;
    54. background: #fff;
    55. border: 1px solid #eaeaea;
    56. text-align: left;
    57. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    58. }
    59. .title {
    60. margin: 0px auto 40px auto;
    61. text-align: center;
    62. color: #505458;
    63. }
    64. style>

    Register.vue

    3.2 将创建好的组件配置到路由中

    index.js

    1. import Vue from 'vue'
    2. import Router from 'vue-router'
    3. import HelloWorld from '@/components/HelloWorld'
    4. import Login from '@/views/Login'
    5. import Register from '@/views/Register'
    6. Vue.use(Router)
    7. export default new Router({
    8. routes: [//默认首页
    9. {
    10. path: '/',
    11. name: 'Login',
    12. component: Login
    13. }, {
    14. path: '/Register',
    15. name: 'Register',
    16. component: Register
    17. }, {
    18. path: '/Login',
    19. name: 'Login',
    20. component: Login
    21. }
    22. ]
    23. })

    3.3 将App.vue的style覆盖

    1. <style>
    2. html,
    3. body {
    4. width: 100%;
    5. height: 100%;
    6. box-sizing: border-box;
    7. padding: 0px;
    8. margin: 0px;
    9. }
    10. #app {
    11. font-family: "Avenir", Helvetica, Arial, sans-serif;
    12. -webkit-font-smoothing: antialiased;
    13. -moz-osx-font-smoothing: grayscale;
    14. color: #2c3e50;
    15. widows: 100%;
    16. height: 100%;
    17. }
    18. style>

    3.5页面展示效果

     

    三、编写实现功能

    1. IDEA中导入项目

     导入项目之后还要修改Maven的配置地址、jdbc、tomcat等等

     2. 安装axio依赖及导入

    npm i axios -S    axios之get请求

    npm install qs -S  post请求

    下载安装vue-axios:  npm i vue-axios -S

     

     导入

    1. import axios from 'axios'
    2. //在main.js中添加
    3. import axios from '@/api/http'
    4. import VueAxios from 'vue-axios'
    5. Vue.use(VueAxios,axios)

    3.UserController控制器

    1. package com.zking.ssm.controller;
    2. import com.zking.ssm.service.IUserService;
    3. import com.zking.ssm.util.JsonResponseBody;
    4. import com.zking.ssm.util.PageBean;
    5. import com.zking.ssm.vo.UserVo;
    6. import org.springframework.beans.factory.annotation.Autowired;
    7. import org.springframework.stereotype.Controller;
    8. import org.springframework.web.bind.annotation.RequestMapping;
    9. import org.springframework.web.bind.annotation.ResponseBody;
    10. import javax.servlet.http.HttpServletRequest;
    11. import javax.servlet.http.HttpServletResponse;
    12. import java.util.List;
    13. import java.util.Map;
    14. @Controller
    15. @RequestMapping("/user")
    16. public class UserController {
    17. @Autowired
    18. private IUserService userService;
    19. @RequestMapping("/userLogin")
    20. @ResponseBody
    21. public JsonResponseBody userLogin(UserVo userVo, HttpServletResponse response){
    22. if(userVo.getUsername().equals("admin")&&userVo.getPassword().equals("123")){
    23. //私有要求claim
    24. // Map json=new HashMap();
    25. // json.put("username", userVo.getUsername());
    26. //生成JWT,并设置到response响应头中
    27. // String jwt=JwtUtils.createJwt(json, JwtUtils.JWT_WEB_TTL);
    28. // response.setHeader(JwtUtils.JWT_HEADER_KEY, jwt);
    29. return new JsonResponseBody<>("用户登陆成功!",true,0,null);
    30. }else{
    31. return new JsonResponseBody<>("用户名或密码错误!",false,0,null);
    32. }
    33. }
    34. @RequestMapping("/queryUserPager")
    35. @ResponseBody
    36. public JsonResponseBody>>
    37. queryUserPager(UserVo userVo, HttpServletRequest request){
    38. try {
    39. PageBean pageBean=new PageBean();
    40. pageBean.setRequest(request);
    41. List> users = userService.queryUserPager(userVo, pageBean);
    42. return new JsonResponseBody<>("OK",true,pageBean.getTotal(),users);
    43. } catch (Exception e) {
    44. e.printStackTrace();
    45. return new JsonResponseBody<>("分页查询用户信息失败!",false,0,null);
    46. }
    47. }
    48. //注册方法
    49. @RequestMapping("/userRegister")
    50. @ResponseBody
    51. public JsonResponseBody userRegister(UserVo user, HttpServletResponse response) {
    52. int i = userService.insertSelective(user);
    53. if (i > 0) {
    54. return new JsonResponseBody<>("用户注册成功!", true, 0, null);
    55. } else {
    56. return new JsonResponseBody<>("用户注册失败!", false, 0, null);
    57. }
    58. }
    59. }

    4.action.js配置

    1. /**
    2. * 对后台请求的地址的封装,URL格式如下:
    3. * 模块名_实体名_操作
    4. */
    5. export default {
    6. 'SERVER': 'http://localhost:8080/user/userLogin', //服务器
    7. 'SYSTEM_USER_DOLOGIN': '/user/userLogin', //登陆
    8. 'SYSTEM_USER_DOREG': '/user/userRegister', //注册
    9. 'getFullPath': k => { //获得请求的完整地址,用于mockjs测试时使用
    10. return this.SERVER + this[k];
    11. }
    12. }

    5. 设置点击事件实现前后端交互

     Login.vue

    1. <template>
    2. <div class="login">
    3. <template>
    4. <div class="login-wrap">
    5. <el-form class="login-container">
    6. <h1 class="title">君易官网登录h1>
    7. <el-form-item label="">
    8. <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off">el-input>
    9. el-form-item>
    10. <el-form-item label="">
    11. <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off">el-input>
    12. el-form-item>
    13. <el-form-item>
    14. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交el-button>
    15. el-form-item>
    16. <el-row style="text-align: center;margin-top:-10px">
    17. <el-link type="primary">忘记密码el-link>
    18. <el-link type="primary" @click="gotoRegister()">用户注册el-link>
    19. el-row>
    20. el-form>
    21. div>
    22. template>
    23. div>
    24. template>
    25. <script>
    26. import axios from 'axios'
    27. export default {
    28. name: 'Login',
    29. data() {
    30. return {
    31. msg: 'Welcome to Your Vue.js App',
    32. username: '',
    33. password: ''
    34. }
    35. },
    36. methods: {
    37. gotoRegister() {
    38. // 跳转注册页面
    39. this.$router.push('/Register');
    40. },
    41. doSubmit() {
    42. let url = 'http://localhost:8080/user/userLogin';
    43. let params = {
    44. username: this.username,
    45. password: this.password
    46. }
    47. // $.ajaxthen相当于success
    48. axios.get(url, {
    49. params: params
    50. }).then(r => {
    51. console.log(r)
    52. if (r.data.success) {
    53. this.$message({
    54. message: r.data.msg,
    55. type: 'success'
    56. });
    57. } else {
    58. this.$message.error(r.data.msg);
    59. }
    60. }).catch(e => {
    61. })
    62. }
    63. }
    64. }
    65. script>
    66. <style scoped>
    67. .login-wrap {
    68. box-sizing: border-box;
    69. width: 100%;
    70. height: 100%;
    71. padding-top: 10%;
    72. background-image: url();
    73. /* background-color: #112346; */
    74. background-repeat: no-repeat;
    75. background-position: center right;
    76. background-size: 100%;
    77. }
    78. .login-container {
    79. border-radius: 10px;
    80. margin: 0px auto;
    81. width: 350px;
    82. padding: 30px 35px 15px 35px;
    83. background: #fff;
    84. border: 1px solid #eaeaea;
    85. text-align: left;
    86. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    87. }
    88. .title {
    89. margin: 0px auto 40px auto;
    90. text-align: center;
    91. color: #505458;
    92. }
    93. style>

     Register.vue

    1. <template>
    2. <div class="register">
    3. <template>
    4. <div class="login-wrap">
    5. <el-form class="login-container">
    6. <h1 class="title">君易官网注册h1>
    7. <el-form-item label="">
    8. <el-input type="text" v-model="username" placeholder="注册账号" autocomplete="off">el-input>
    9. el-form-item>
    10. <el-form-item label="">
    11. <el-input type="password" v-model="password" placeholder="注册密码" autocomplete="off">el-input>
    12. el-form-item>
    13. <el-form-item>
    14. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交el-button>
    15. el-form-item>
    16. <el-row style="text-align: center;margin-top:-10px">
    17. <el-link type="primary">重置el-link>
    18. <el-link type="primary" @click="gotoLogin()">用户登陆el-link>
    19. el-row>
    20. el-form>
    21. div>
    22. template>
    23. div>
    24. template>
    25. <script>
    26. export default {
    27. name: 'Register',
    28. data () {
    29. return {
    30. msg: 'Welcome to Your Vue.js App',
    31. username:'',
    32. password:''
    33. }
    34. },
    35. methods: {
    36. gotoLogin() {
    37. // 跳转登陆页面
    38. this.$router.push('/Login');
    39. }doSubmit() {
    40. //定义后台注册方法连接地址
    41. let url = this.axios.urls.SYSTEM_USER_DOREG;
    42. //获取数据
    43. let params = {
    44. username: this.username,
    45. password: this.password
    46. };
    47. /* post请求方式 */
    48. this.axios.post(url, params).then(r => {
    49. //判断是否注册成功
    50. if (r.data.success) {
    51. //利用ElementUI信息提示组件返回登录信息
    52. this.$message({
    53. message: r.data.msg,
    54. type: 'success'
    55. });
    56. //注册成功,返回指定界面
    57. //this.$route.push('主界面');
    58. } else {
    59. //弹出注册失败信息
    60. this.$message.error(r.data.msg);
    61. }
    62. }).catch(function(error) {
    63. console.log(error);
    64. });
    65. }
    66. }
    67. }
    68. script>
    69. <style scoped>
    70. .login-wrap {
    71. box-sizing: border-box;
    72. width: 100%;
    73. height: 100%;
    74. padding-top: 10%;
    75. background-image: url();
    76. /* background-color: #112346; */
    77. background-repeat: no-repeat;
    78. background-position: center right;
    79. background-size: 100%;
    80. }
    81. .login-container {
    82. border-radius: 10px;
    83. margin: 0px auto;
    84. width: 350px;
    85. padding: 30px 35px 15px 35px;
    86. background: #fff;
    87. border: 1px solid #eaeaea;
    88. text-align: left;
    89. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    90. }
    91. .title {
    92. margin: 0px auto 40px auto;
    93. text-align: center;
    94. color: #505458;
    95. }
    96. style>

    页码效果演示

     

     四、跨域问题

            跨域问题指的是在浏览器中,当一个网页的 JavaScript 代码试图向不同源(协议、域名、端口号任意一个不同)的服务器发送请求时,浏览器会阻止这个请求,称之为跨域请求。这是由于浏览器的同源策略所导致的安全机制。

            同源策略是一种浏览器安全策略,用于保护用户的隐私和数据安全。它规定了网页上的 JavaScript 只能与同源(协议、域名、端口号完全一致)的服务器进行通信,而不能与其他域名下的服务器进行直接交互。

            跨域问题的出现是为了防止恶意网站通过 JavaScript 访问其他网站的用户隐私数据。然而,在实际开发中,有时我们需要进行跨域请求,例如通过 AJAX 请求获取数据或调用远程 API。因此,为了解决跨域问题,可以采取一些措施,如修改服务器端的 CORS 策略、使用代理服务器或 JSONP 等方法来允许跨域请求的发送。

     解决方案:

    最简单的方式是自己写一个过滤器CorsFilter实现,添加一个响应头Access-Control-Allow-Origin即可

    1. package com.zking.ssm.util;
    2. import java.io.IOException;
    3. import javax.servlet.Filter;
    4. import javax.servlet.FilterChain;
    5. import javax.servlet.FilterConfig;
    6. import javax.servlet.ServletException;
    7. import javax.servlet.ServletRequest;
    8. import javax.servlet.ServletResponse;
    9. import javax.servlet.http.HttpServletResponse;
    10. /**
    11. * 配置tomcat允许跨域访问
    12. *
    13. * @author Administrator
    14. *
    15. */
    16. public class CorsFilter2 implements Filter {
    17. @Override
    18. public void init(FilterConfig filterConfig) throws ServletException {
    19. }
    20. @Override
    21. public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
    22. throws IOException, ServletException {
    23. HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
    24. // Access-Control-Allow-Origin就是我们需要设置的域名
    25. // Access-Control-Allow-Headers跨域允许包含的头。
    26. // Access-Control-Allow-Methods是允许的请求方式
    27. httpResponse.setHeader("Access-Control-Allow-Origin", "*");// *,任何域名
    28. httpResponse.setHeader("Access-Control-Allow-Headers", "responseType,Origin, X-Requested-With, Content-Type, Accept");
    29. httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
    30. //允许客户端处理一个新的响应头jwt
    31. //httpResponse.setHeader("Access-Control-Expose-Headers", "jwt,Content-Disposition");
    32. filterChain.doFilter(servletRequest, servletResponse);
    33. }
    34. @Override
    35. public void destroy() {
    36. }
    37. }
    1. <filter>
    2. <filter-name>corsFilterfilter-name>
    3. <filter-class>com.zking.ssm.util.CorsFilter2filter-class>
    4. filter>
    5. <filter-mapping>
    6. <filter-name>corsFilterfilter-name>
    7. <url-pattern>/*url-pattern>
    8. filter-mapping>

    将上述代码配置到web.xm即可

    本期分享到此结束,希望老铁三连加关注支持一波。

     

  • 相关阅读:
    简述React 和 Vue 的 diff 时间复杂度从 O(n^3) 优化 到 O(n) ,那么 O(n^3) 和 O(n) 是如何计算出来的 ?
    mvc core基于Asp Net的印刷网站
    K8S基础架构租赁(Lease )
    Godot4实现游戏的多语言版本
    Spark RDD机制(持久化、依赖关系、checkpoint)
    Transformer-深度学习-台湾大学李宏毅-课程笔记
    竟敢冒充国家级黑客组织!亚信安全还原攻击事件真实面貌
    java.lang.Float类下doubleValue()方法具有什么功能呢?
    指纹浏览器开发指南-EasyBR
    新手如何使用Cheat Engine (CE) 来修改“我的世界“?
  • 原文地址:https://blog.csdn.net/weixin_74352229/article/details/133181402