• ElementUI之登陆+注册


    ElementUI

    ElementUI是什么

    ElementUI是一个基于Vue.js 2.0的UI组件库,它提供了一系列常用的前端UI组件,如按钮、表格、轮播图、弹窗等,可以帮助开发者快速搭建美观、易用的前端页面。ElementUI还提供了一套完整的主题定制方案,开发者可以根据自己的需求自定义主题风格。作为一个开源项目,ElementUI的源码也是公开的,可以自由地查看和修改。

    ElementUI的特点

    1.丰富的组件库,覆盖了常用的UI组件,如按钮、表格、轮播图、弹窗等。

    2.易于使用和定制,提供了灵活的参数和API,开发者可以根据自己的需求进行定制。

    3.良好的兼容性,支持各种浏览器以及移动端的响应式设计。

    4.提供了一套完整的主题定制方案,开发者可以根据自己的需求自定义主题风格。

    5.开源免费,可以免费使用、修改和分发,同时也可以参与贡献,提供反馈和建议。

    ElementUl导入 

    首先 CMD命令窗口,并跳转到指定工作目录下创建项目,输入vue init webpack spa 创造我们的项目 spa 是我们的项目名 大家可以看:使用vue-cli搭建SPA项目_浊酒与说心事的博客-CSDN博客

    使用CMD命令窗口,并跳转到指定项目的目录下面使用命令npm install element-ui -S,添加Element-UI模块到项目中

    我们可以打开package.json观看

     Element搭建登入注册

    经过上文使用vue-cli搭建SPA项目_浊酒与说心事的博客-CSDN博客 在我们所以写的代码下,还原来的代码

    main.js

    并且在我们的main.js中添加如下代码

    1. // The Vue build version to load with the `import` command
    2. // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
    3. import Vue from 'vue'
    4. // 新添加1
    5. import ElementUI from 'element-ui'
    6. // 新添加2,避免后期打包样式不同,要放在import App from './App';之前
    7. import 'element-ui/lib/theme-chalk/index.css'
    8. import App from './App'
    9. import router from './router'
    10. // 新添加3
    11. Vue.use(ElementUI)
    12. Vue.config.productionTip = false
    13. Vue.config.productionTip = false
    14. /* eslint-disable no-new */
    15. new Vue({
    16. el: '#app',
    17. router,
    18. components: { App },
    19. template: ''
    20. })

     views

    views用来存储我们的Login,以及Register,这两个是应用于页面

     Login.vue

    Login是我们的登入页面,用途登入

     在我们的Login.vue中写入以下代码

    1. <template>
    2. <!-- <div class="login-wrap"> -->
    3. <el-form class="login-container">
    4. <h1 class="title">用户登录</h1>
    5. <el-form-item label="">
    6. <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off"></el-input>
    7. </el-form-item>
    8. <el-form-item label="">
    9. <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off"></el-input>
    10. </el-form-item>
    11. <el-form-item>
    12. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
    13. </el-form-item>
    14. <el-row style="text-align: center;margin-top:-10px">
    15. <el-link type="primary">忘记密码</el-link>
    16. <el-link type="primary" @click="gotoRegister()">用户注册</el-link>
    17. </el-row>
    18. </el-form>
    19. </div>
    20. </template>
    21. <script>
    22. export default{
    23. name:'Login',
    24. data(){
    25. return{
    26. username: '',
    27. password:'',
    28. }
    29. }
    30. ,methods:{
    31. gotoRegister(){
    32. this.$router.push('/Register');
    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
    1. <template>
    2. <!-- <div class="login-wrap"> -->
    3. <el-form class="login-container">
    4. <h1 class="title">用户注册</h1>
    5. <el-form-item label="">
    6. <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off"></el-input>
    7. </el-form-item>
    8. <el-form-item label="">
    9. <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off"></el-input>
    10. </el-form-item>
    11. <el-form-item>
    12. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
    13. </el-form-item>
    14. <el-row style="text-align: center;margin-top:-10px">
    15. <el-link type="primary">忘记密码</el-link>
    16. <el-link type="primary" @click="gotoLogin()">用户登入</el-link>
    17. </el-row>
    18. </el-form>
    19. </div>
    20. </template>
    21. <script>
    22. export default{
    23. name:'Login',
    24. data(){
    25. return{
    26. username: '',
    27. password:'',
    28. }
    29. }
    30. ,methods:{
    31. gotoLogin(){
    32. this.$router.push('/');
    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>

     数据交互

    在前端的spa项目中,在本地的根本路径下,Win+R,输入cmd,打开cmd窗口。

    输入以下命令安装所需模块 : 

    npm i axios -S       npm i qs-S

    引用模块


    安装后就在项目中进行引用,添加axios的全局配置,创建一个actio.js

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

    创建http.js,用于vue项目对axios的全局配置

    1. /**
    2. * vue项目对axios的全局配置
    3. */
    4. import axios from 'axios'
    5. import qs from 'qs'
    6. //引入action模块,并添加至axios的类属性urls上
    7. import action from '@/api/action'
    8. axios.urls = action
    9. // axios默认配置
    10. axios.defaults.timeout = 10000; // 超时时间
    11. // axios.defaults.baseURL = 'http://localhost:8080/j2ee15'; // 默认地址
    12. axios.defaults.baseURL = action.SERVER;
    13. //整理数据
    14. // 只适用于 POST,PUT,PATCH,transformRequest` 允许在向服务器发送前,修改请求数据
    15. axios.defaults.transformRequest = function(data) {
    16. data = qs.stringify(data);
    17. return data;
    18. };
    19. // 请求拦截器
    20. axios.interceptors.request.use(function(config) {
    21. return config;
    22. }, function(error) {
    23. return Promise.reject(error);
    24. });
    25. // 响应拦截器
    26. axios.interceptors.response.use(function(response) {
    27. return response;
    28. }, function(error) {
    29. return Promise.reject(error);
    30. });
    31. // // 路由请求拦截
    32. // // http request 拦截器
    33. // axios.interceptors.request.use(
    34. // config => {
    35. // //config.data = JSON.stringify(config.data);
    36. // //config.headers['Content-Type'] = 'application/json;charset=UTF-8';
    37. // //config.headers['Token'] = 'abcxyz';
    38. // //判断是否存在ticket,如果存在的话,则每个http header都加上ticket
    39. // // if (cookie.get("token")) {
    40. // // //用户每次操作,都将cookie设置成2小时
    41. // // cookie.set("token", cookie.get("token"), 1 / 12)
    42. // // cookie.set("name", cookie.get("name"), 1 / 12)
    43. // // config.headers.token = cookie.get("token");
    44. // // config.headers.name = cookie.get("name");
    45. // // }
    46. // return config;
    47. // },
    48. // error => {
    49. // return Promise.reject(error.response);
    50. // });
    51. // // 路由响应拦截
    52. // // http response 拦截器
    53. // axios.interceptors.response.use(
    54. // response => {
    55. // if (response.data.resultCode == "404") {
    56. // console.log("response.data.resultCode是404")
    57. // // 返回 错误代码-1 清除ticket信息并跳转到登录页面
    58. // // cookie.del("ticket")
    59. // // window.location.href='http://login.com'
    60. // return
    61. // } else {
    62. // return response;
    63. // }
    64. // },
    65. // error => {
    66. // return Promise.reject(error.response) // 返回接口返回的错误信息
    67. // });
    68. export default axios;

    GET请求

    登入组件中进行axios的get请求,编写Login.vue的代码,将script标签的代码修改为以下代码进行get请求

    1. <script>
    2. import axios from 'axios'
    3. export default {
    4. name: 'Login',
    5. data() {
    6. return {
    7. username: "",
    8. password: "",
    9. msg: '国产还是什么?'
    10. }
    11. },
    12. methods: {
    13. Register() {
    14. this.$router.push('/Register');
    15. },
    16. doSubmit() {
    17. let params = {
    18. username: this.username,
    19. password: this.password
    20. };
    21. console.log(params);
    22. //定义后端都请求地址
    23. var url = "http://localhost:8080/ssm/user/userLogin";
    24. //注意数据是保存到json对象的params属性
    25. //进行请求携带数据进行登入访问
    26. axios.get(url, {
    27. //携带的参数(数据)
    28. params: params,
    29. }).then(r => {
    30. //如果携带的参数数据跟后端数据对应正确,说明登入成功,提示
    31. if(r.data.success){
    32. this.$message({
    33. showClose: true,
    34. message: r.data.msg,
    35. type: 'success'
    36. });
    37. }else{
    38. //如果携带的参数数据跟后端数据对应错误,说明登入失败,提示
    39. this.$message.error(r.data.msg);
    40. }
    41. console.log(r);
    42. }).catch(e => {
    43. console.log(e);
    44. });
    45. }
    46. }
    47. }
    48. </script>

    在我们的的后端项目中,有一个视图解析器来处理我们前端发过来的请求进行处理

    1. package com.ssm.controller;
    2. import com.ssm.service.IUserService;
    3. import com.ssm.util.JsonResponseBody;
    4. import com.ssm.util.PageBean;
    5. import com.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.HashMap;
    13. import java.util.List;
    14. import java.util.Map;
    15. import com.ssm.jwt.*;
    16. @zhanghao
    17. @RequestMapping("/user")
    18. public class UserController {
    19. @Autowired
    20. private IUserService userService;
    21. @RequestMapping("/userLogin")
    22. @ResponseBody
    23. public JsonResponseBody<?> userLogin(UserVo userVo, HttpServletResponse response){
    24. if(userVo.getUsername().equals("admin")&&userVo.getPassword().equals("123")){
    25. //私有要求claim
    26. // Map<String,Object> json=new HashMap<String,Object>();
    27. // json.put("username", userVo.getUsername());
    28. //生成JWT,并设置到response响应头中
    29. // String jwt=JwtUtils.createJwt(json, JwtUtils.JWT_WEB_TTL);
    30. // response.setHeader(JwtUtils.JWT_HEADER_KEY, jwt);
    31. return new JsonResponseBody<>("用户登陆成功!",true,0,null);
    32. }else{
    33. return new JsonResponseBody<>("用户名或密码错误!",false,0,null);
    34. }
    35. }
    36. @RequestMapping("/queryUserPager")
    37. @ResponseBody
    38. public JsonResponseBody<List<Map<String,Object>>>
    39. queryUserPager(UserVo userVo, HttpServletRequest request){
    40. try {
    41. PageBean pageBean=new PageBean();
    42. pageBean.setRequest(request);
    43. List<Map<String, Object>> users = userService.queryUserPager(userVo, pageBean);
    44. return new JsonResponseBody<>("OK",true,pageBean.getTotal(),users);
    45. } catch (Exception e) {
    46. e.printStackTrace();
    47. return new JsonResponseBody<>("分页查询用户信息失败!",false,0,null);
    48. }
    49. }
    50. }

    紧接着在前端项目的根本路径打开我们的cmd窗口npm run dev运行

  • 相关阅读:
    Linux之 USB驱动框架-USB鼠标驱动源码分析(5)
    李沐——论文阅读——VIT(VIsionTransformer)
    STM32——SPI通信实验
    Three.js动效(第15辑):让前端手撕UI,拳打后端的效果。
    Redis
    vue3.0运行npm run dev 报错Cannot find module ‘node:url‘
    ecology中前端ecode二次开发查询/更新后端数据库
    【图论C++】链式前向星(图(树)的存储)
    我的Vue之旅 07 Axios + Golang + Sqlite3 实现简单评论机制
    有监督学习——高斯过程
  • 原文地址:https://blog.csdn.net/djssubddbj/article/details/133260862