当前位置:   article > 正文

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

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

文档部分

这边使用是开源的API

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

返回格式 : json/images

请求方式:  get/post

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

请求参数

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

返回参数

返回参数列表
名称类型说明
codestring返回的状态码
imgUrlstring返回图片地址
msgstring返回错误提示消息

返回实例

  1. {
  2. "code": 1,
  3. "imgurl": "https:\/\/ws2.sinaimg.cn\/large\/005zWjpngy1fuvgjtiihyj31400p0ajp.jpg"
  4. }

 实例

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

实现方式

html 部分

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

js部分

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

实现步骤 

html代码

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

  1. //可以让元素水平排列 mode="horizontal
  2. //@select 当选择该元素时候会调用该方法
  3. <el-menu mode="horizontal"
  4. @select="handleSelect">
  5. <el-menu-item index="1" disabled>头像</el-menu-item>
  6. <el-menu-item index="男" ></el-menu-item>
  7. <el-menu-item index="女" ></el-menu-item>
  8. <el-menu-item index="动漫男" >动漫男</el-menu-item>
  9. <el-menu-item index="动漫女" >动漫女</el-menu-item>
  10. </el-menu>

接受响应回的参数

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

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

js部分

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

  1. import {ref} from "vue";
  2. import axios from "axios";
  3. import {ElMessage} from "element-plus";
  4. import qs from "qs";

定义请求参数和返回参数

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

 调用方法

  1. const handleSelect =(index)=>{
  2. if (index === '1') {
  3. // 如果第一项被点击(但它被禁用了),这里不会执行
  4. return;
  5. }
  6. postAvatar.value.sort = index;
  7. let data = qs.stringify(postAvatar.value);
  8. console.log(selectedAvatarUrl.value)
  9. // 调用 API 获取头像 URL
  10. axios.get(`https://api.uomg.com/api/rand.avatar?`+data) // 假设 API 支持 sort 参数
  11. .then((response) => {
  12. // 假设 API 返回了一个包含图片 URL 的对象
  13. if (response.data.code==1) { // 根据你的 API 响应结构进行调整
  14. selectedAvatarUrl.value = response.data.imgurl; // 更新图片 URL
  15. ElMessage.success("头像加载成功");
  16. } else {
  17. ElMessage.error(response.data.msg);
  18. }
  19. })
  20. .catch((error) => {
  21. ElMessage.error("加载头像时发生错误:" + error.message);
  22. });
  23. };

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小蓝xlanll/article/detail/667027
推荐阅读
相关标签
  

闽ICP备14008679号