Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四

1.根据验证结果,向服务器发起数据请求

1.1 根据预验证结果进行判断,如果结果为false,不发起请求。

  • 如果向服务器发起请求,就需要用到一个包,这个包叫 Axios ;

1.2 配置Axios包 

  • 打开程序入口文件 main.js ,对Axios这个包进行全局配置

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第1张图片

  • 引入Axios
  • 把这个包挂载在Vue 原型对象上
  • 挂载的意思是,每一个组件,都可以通过this访问到 $http,从而发起ajax请求。

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第2张图片

  •  设置接口请求根路径,根据提供的接口文档进行设置。如图接口文档根路径 

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第3张图片 代码配置如图,axios会提供一个defaults.baseURL进行根路径配置

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第4张图片

 踏坑小助手:

  1. vue 2.0 中是直接使用Vue.prototype.$http=axios

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第5张图片

  1. vue 3.0 中使用了app.config.globalProperties.$axios = axios 进行替换了prototype

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第6张图片

 1.3 组件通过this访问挂载在vue上面的$http,通过$http发起登录请求

  1. 请求地址和方法,参考文档

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第7张图片   

2. 由于用户填写的表单数据,都会保存在表单数据form对象里面。所以请求方法后面,直接填表单数据对象。

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第8张图片

  3. 开启服务器,保证服务器运行中。参考(17条消息) Vue+Element-UI 前后端分离开发四(项目初始化)_码侬人生-CSDN博客

 1.4 使用const 进行接收请求返回的数据

  •  先输出在控制台,打印看看结果

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第9张图片

  •  可以看到返回的结果是Promise。

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第10张图片

  1.  什么是Promise,看百度结果

Promise 是异步编程的一种解决方案: 从语法上讲,promise是一个对象,从它可以获取异步操作的消息;从本意上讲,它是承诺,承诺它过一段时间会给你一个结果。 promise有三种状态:pending(等待态),fulfiled(成功态),rejected(失败态);状态一旦改变,就不会再变。创造promise实例后,它会立即执行。 

    2. 如何解决某个方法返回 Promise的结果。如上理解了,就是它需要使用异步进行访问。

  • 使用await async
  • await只能使用在async修饰的方法中

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第11张图片

    3. 接下来,再次发起请求,使用console.log查看一下result对象,看看还是不是promise对象。

如图,已经不再是promise对象了,而是一个具体响应对象

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第12张图片

   4. 该响应对象,包括了6个对象属性,config、data、headers、status、statusText。这6个属性都是Axios自动帮我们封装好的。其中 data 才是服务器返回的真实数据。换名话说,除了data属性,其他属性根本不需要。

   5. 由于data属性是一个json对象,我们需要进行解构赋值出来。可以直接使用接收的对象result 进行解构赋值。

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第13张图片

 1.4 如何解构赋值

  1.  通过花括号进行解构赋值

     2. 查看控制台,已经解构成功。

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第14张图片

  3. 进行meta 响应对象里面的状态码判断

  •  如果状态码等于200,证明登录成功。不等于200,登录失败。

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第15张图片 4. 如图,填入正确的用户,就会显示登录成功了

Vue3+Element-Plus 登录功能向服务器起发后台数据请求实现十四_第16张图片

 1.5 代码

 main.js

import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import installElementPlus from './plugins/element'
// 导入字体图标
import './assets/font/iconfont.css'
// 导入全局样式表
import './assets/css/global.css'

import axios from 'axios'
// 配置请求根路径
axios.defaults.baseURL = 'http://127.0.0.1:8888/api/private/v1/'
const app = createApp(App)
installElementPlus(app)
app.config.globalProperties.$http = axios
app.use(router).mount('#app')

 Login.vue






 以上出自于:【黑马程序员】前端开发之Vue项目实战_Element-UI【配套源码+笔记】_哔哩哔哩_bilibiliicon-default.png?t=LA92https://www.bilibili.com/video/BV1x64y1S7S7?p=1

你可能感兴趣的:(前端开发,vue.js,javascript,npm)