vue3-调用API实操-调用开源头像接口

文档部分

这边使用是开源的API

请求地址: **:**https://api.uomg.com/api/rand.avatar

返回格式 : json/images

请求方式: get/post

请求实例: https://api.uomg.com/api/rand.avatar?sort=男&format=json

请求参数

|--------|----|--------|---------------------------------|
| 名称 | 必填 | 类型 | 说明 |
| sort | 否 | string | 选择输出分类男\|女\|动漫男\|动漫女,为空随机输出 |
| format | 否 | string | 选择输出格式json\|images |
[请求参数说明]

返回参数

|--------|--------|----------|
| 名称 | 类型 | 说明 |
| code | string | 返回的状态码 |
| imgUrl | string | 返回图片地址 |
| msg | string | 返回错误提示消息 |
[返回参数列表]

返回实例

javascript 复制代码
{
 "code": 1,
 "imgurl": "https:\/\/ws2.sinaimg.cn\/large\/005zWjpngy1fuvgjtiihyj31400p0ajp.jpg"
}

实例

实现效果 : 点击头像菜单栏可以更换不同的头像

实现方式

html 部分

  • 利用 element-plus中的<el-menu></el-menu> 更改请求参数
  • 绑定一个响应式变量显示在页面

js部分

  • 定义响应式变量
  • 接受请求参数
  • 定义一个返回的参数
  • 定义一个函数 利用 axios跨域 接受接口返回的值

实现步骤

html代码

mode="horizontal 可以让元素水平排列
@select="方法" 当选择该元素时候会调用该方法

html 复制代码
//可以让元素水平排列 mode="horizontal
//@select 当选择该元素时候会调用该方法
<el-menu  mode="horizontal"
            @select="handleSelect">
    <el-menu-item index="1" disabled>头像</el-menu-item>
    <el-menu-item index="男" >男</el-menu-item>
    <el-menu-item index="女" >女</el-menu-item>
    <el-menu-item index="动漫男" >动漫男</el-menu-item>
    <el-menu-item index="动漫女" >动漫女</el-menu-item>
  </el-menu>

接受响应回的参数

v-if ='布尔值' 用来是否在页面显示 true为显示 false为不显示
<el-avatar></el-avatar> 是element-plus 头像组件

html 复制代码
//v-if 用来是否在页面显示 true为显示 false为不显示
//<el-avatar></el-avatar> 是element-plus 头像组件
<div v-if="selectedAvatarUrl">
    <el-avatar :size="300" :src="selectedAvatarUrl" />
<!--    <img :src="selectedAvatarUrl" alt="Avatar" style="max-width: 100%; width: 500px; height: auto;"/>-->
  </div>

js部分

导包 (记得配置这些导包项)

javascript 复制代码
import {ref} from "vue";
import axios from "axios";
import {ElMessage} from "element-plus";
import qs from "qs";

定义请求参数和返回参数

java 复制代码
const selectedAvatarUrl = ref(''); // 用于存储选中的头像 URL
const postAvatar = ref({ sort: '', format: 'json' }); // 通常 API 不需要 format 参数,除非它确实需要

调用方法

javascript 复制代码
const handleSelect =(index)=>{


  if (index === '1') {
    // 如果第一项被点击(但它被禁用了),这里不会执行
    return;
  }
  postAvatar.value.sort = index;
  let data = qs.stringify(postAvatar.value);
console.log(selectedAvatarUrl.value)
  // 调用 API 获取头像 URL
  axios.get(`https://api.uomg.com/api/rand.avatar?`+data) // 假设 API 支持 sort 参数
      .then((response) => {
        // 假设 API 返回了一个包含图片 URL 的对象
        if (response.data.code==1) { // 根据你的 API 响应结构进行调整
          selectedAvatarUrl.value = response.data.imgurl; // 更新图片 URL
          ElMessage.success("头像加载成功");
        } else {
          ElMessage.error(response.data.msg);
        }
      })
      .catch((error) => {
        ElMessage.error("加载头像时发生错误:" + error.message);
      });
};
相关推荐
IT_陈寒2 小时前
Vue这个坑我跳了两次,原来问题出在这
前端·人工智能·后端
kyriewen2 小时前
我用 50 行代码重写了 React Router 核心,终于搞懂了前端路由原理
前端·javascript·react.js
WebInfra3 小时前
Rspack 2.1 发布:React Compiler 提速 10 倍!
前端
李明卫杭州3 小时前
CSS 媒体查询详解:一文掌握响应式设计的核心技术
前端
lichenyang4534 小时前
从 H5 按钮到 OpenHarmony 能力调用:我如何理解 ASCF 的运行链路
前端
下家4 小时前
我放弃了 Vue/React,选择自研框架
前端·前端框架
Asize5 小时前
HTML5 Canvas 基础:从按帧动画到 ECharts 数据可视化
前端·javascript·canvas
默_笙5 小时前
🎄 后端给我一堆扁平数据,我 10 行代码把它变成了树
前端·javascript
Mahut5 小时前
我用 Electron + FFmpeg 做了一个本地视频处理工作站 ClipForge
前端·ffmpeg·electron
前端Hardy5 小时前
又一个 AI 神器火了!
前端·javascript·后端