Vue项目中的接口调用

在企业开发过程中,往往有着明确的前后端的分工,前端负责接收、使用接口,后端负责编写、处理接口。

对于前端如何使用接口,今天在Vue中进行讲解。

一个项目往往由这几个部分组成。

在这里插入图片描述
其中在src文件夹中,在这里插入图片描述,有这么些内容。

我们常常把接口文件,新建一个文件夹在src下,命名为api,api内的文件便是接口文件。

在这里插入图片描述

通常把后端的接口写在api文件夹下,自己命名为xxx.js

// 登录
export function login(data) {
  return request({
    url: '/api/court/login',
    method: 'post',
    data
  })
}
// 获取验证码
export function captchaImage(params) {
  return request({
    url: '/api/captchaImage',
    method: 'get',
    params
  })
}

对于需要添加信息在头部的,可以这么写

// 获取登录用户信息
export function getInfo(params) {
  return request({
    url: '/api/court/getInfo',
    method: 'get',
    params,
    headers: {
      'Authorization': JSON.parse(localStorage.Authorization)
  }
  })
}

在这里插入图片描述
这个就是request.js 文件的内容在这里插入图片描述

import axios from 'axios'
// import { getToken } from '@/utils/auth'

// create an axios instance
const service = axios.create({
  // 外网更新
  // baseURL: 'http://xxxxx',
  baseURL: '/xxxxx',  
  timeout: 5000 // request timeout
})

export default service

项目的页面往往写在views中,每个页面设一个文件夹,其中index.vue 内容则是本页面的内容
在这里插入图片描述
在页面中,如果我们需要使用某个接口。则需要进行引入操作。通过 import {接口名1、接口名2} from ’ api文件地址 ’

import { login,captchaImage,getInfo,logOut,reset } from '@/api/login'

from后所跟的就是api中文件的地址路径

接口往往是在方法中进行调用,对于不同接口 ,需要的参数也不一样,根据需求,我们传入对应的参数即可。图中的 captchaImage、以及login就是接口信息。

接口的使用格式:

接口名({参数1:页面中的参1,参数2:页面中的参数2}).then(res => {
console.log(res)//res就是调用接口后,后台返回过来的结果,一般数据储存在res.data.data中,具体情况而论

        })

在这里插入图片描述
这样就是接口调用的全部过程了。附上控制台信息图以及apipost接口图。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

### 回答1: Vue接口返回的二维码流文件是一个二进制数据,在前端中可以通过将流文件转换为Base64编码的字符串来进行处理和展示。可以使用Axios等HTTP请求库发送请求获取二维码流文件,然后将其转换为Base64编码。 首先,在Vue组件中引入Axios库,并发送GET请求获取二维码流文件: ```javascript import axios from 'axios'; axios({ method: 'GET', url: '/api/qrcode', responseType: 'blob' // 设置响应类型为二进制数据流 }).then(response => { const blob = response.data; const reader = new FileReader(); reader.readAsDataURL(blob); // 将二进制数据流转换为Base64编码 reader.onloadend = () => { const base64Data = reader.result; this.qrcodeImage = base64Data; // 将Base64编码的二维码图片赋给组件的数据属性 }; }); ``` 然后,在Vue模板中使用`img`标签来展示Base64编码的二维码图片: ```html <template> <div> <img :src="qrcodeImage" alt="二维码"> </div> </template> ``` 最后,在Vue组件的数据属性中定义`qrcodeImage`用于存储Base64编码的二维码图片: ```javascript export default { data() { return { qrcodeImage: '' }; } } ``` 这样,通过将二维码流文件转换为Base64编码的字符串,我们可以在Vue中展示接口返回的二维码图片。 ### 回答2: Vue 接口返回的二维码流文件,可以通过以下步骤进行处理: 首先,在 Vue 组件中发起请求获取二维码流文件。可以使用 Axios 这样的库来发送 HTTP 请求,并设置响应类型为二进制流。 ```javascript axios({ method: 'GET', url: 'your_api_endpoint', responseType: 'blob' // 设置响应类型为二进制流 }).then(response => { // 处理返回的二维码流文件 const qrCodeBlob = response.data; // ... }).catch(error => { // 处理请求错误 console.error(error); }); ``` 接下来,对返回的二维码流文件进行处理。可以使用 FileSaver.js 这样的库将二进制流保存为二维码图片文件。 ```javascript import { saveAs } from 'file-saver'; // 保存二维码流文件为图片文件 saveAs(qrCodeBlob, 'qrcode.png'); ``` 这样就成功将接口返回的二维码流文件保存为本地的图片文件了。 请注意,以上代码中的 `your_api_endpoint` 是你实际的接口地址,需要替换为正确的值。另外,需要在 Vue 项目中安装并导入 Axios 和 FileSaver.js 这两个库。 希望以上回答能对你有所帮助,如果还有其他疑问,请随时追问。 ### 回答3: 当Vue接收到接口返回的二维码流文件时,可以通过以下方式进行处理: 1. 接口返回的二维码流文件可以是一个二进制流,我们可以使用Vue中的axios库来发送请求获取该接口返回的文件流数据。 2.Vue组件中,通过axios发送请求获取接口返回的二维码流文件。可以使用axios的get方法来发送请求,并将接口地址作为参数传递进去。 3. 在获取到文件流数据后,可以将其转换成Blob对象,可以使用FileReader对象来进行转换。 4. 使用FileReader的readAsDataURL方法将Blob对象转换为data URL,这样可以在前端页面中直接显示这个二维码图片。 5. 将转换后的data URL赋值给Vue组件中的图片对象的src属性,即可在页面上显示二维码图片。 以上是处理Vue接收到接口返回的二维码流文件的一般流程,具体的实现可能需要根据实际情况进行调整和完善。这样,我们就可以在Vue中成功处理接口返回的二维码流文件,并在页面上显示二维码图片。
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我要当前端工程师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值