Vue接口平台学习七——接口调试页面请求体

news2025/4/16 12:41:34

一、实现效果图及简单梳理

在这里插入图片描述
请求体部分的左边,展示参数,分text和file类型。
右边部分一个el-upload的上传文件按钮,一个table列表展示,一个显示框,用于预览选择的文件,点击可大图展示。

二、页面内容实现

0. 整体布局

这里分左右两边,左边用于添加和显示参数,右边用于上传文件和预览文件

<el-row :gutter="5">
    <el-col :span="15">
      
    </el-col>
    <el-col :span="9">
      
    </el-col>
  </el-row>

1. 左边的参数值部分

单个参数

左边包含内容,参数名(输入框),参数类型(下拉选择),参数值(选择text时为输入框,选择file时,为下拉选择),一个删除按钮,一个添加参数按钮

<el-col :span="15">
      <el-row  :gutter="5" style="margin-top: 5px;">
        <el-col :span="5">
          <el-input size="small"  placeholder="参数名" clearable/>
        </el-col>
        <el-col :span="4">
          <el-select v-model="paramsType" placeholder="参数类型" size="small" style="width: 100%;">
            <el-option label="Text" value="text"/>
            <el-option label="File" value="file"/>
          </el-select>
        </el-col>
        <el-col :span="11">
          <!-- 文字输入框 -->
          <el-input v-if="paramsType === 'text'"  placeholder="参数值" size="small"
                    clearable/>
          <el-select v-else  size="small" placeholder="选择已有文件" style="width: 100%;">
            <el-option  value="123"/>
          </el-select>
        </el-col>
        <el-col :span="4">
          <el-button icon="Delete"  size="small" type="danger" plain></el-button>
        </el-col>
      </el-row>
      <el-button style="margin-top: 10px;" icon="Plus" size="small" type="primary" plain></el-button>
    </el-col>

选择Text时
选择File时
单个参数大概就这样,现在需要定义一个变量,用来存储所有参数,然后遍历显示,并且点击添加时,需要向这个列表增加新的值。

多个参数循环遍历

const params = ref([]); // 参数列表 ['name','value']
<el-col :span="15">
      <el-row v-for="(item, index) in params" :key="index" :gutter="5" style="margin-top: 5px;">
        <el-col :span="5">
          <el-input size="small" v-model="item[0]" placeholder="参数名" clearable/>
        </el-col>
        <el-col :span="4">
          <el-select v-model="paramsType[index]" placeholder="参数类型" size="small" style="width: 100%;">
            <el-option label="Text" value="text"/>
            <el-option label="File" value="file"/>
          </el-select>
        </el-col>
        <el-col :span="11">
          <!-- 文字输入框 -->
          <el-input v-if="paramsType[index] === 'text'" v-model="item[1]" placeholder="参数值" size="small"
                    clearable/>
          <el-select v-else v-model="item[1][0]" size="small"  placeholder="选择已有文件" style="width: 100%;">
            <el-option  value="123"/>
          </el-select>
        </el-col>
        <el-col :span="4">
          <el-button icon="Delete"  size="small" type="danger" plain></el-button>
        </el-col>
      </el-row>
      <el-button @click="params.push(['',''])"  style="margin-top: 10px;" icon="Plus" size="small" type="primary" plain></el-button>
    </el-col>

在这里插入图片描述
由于后端定义的文件内容,包含名字,文件类型,文件地址三部分。所以如果选择类型是File,则有包含三部分内容。而下拉选择的仅仅只是绑定文件名,也就是列表第一个值。

删除

绑定点击事件

<el-button icon="Delete" @click="params.splice(index, 1)" size="small" type="danger" plain></el-button></el-col>

从数组中删除元素splice。

文件相关

定义接口

根据接口文档,在vue中封装接口
在这里插入图片描述

页面组件挂载完毕,获取一下文件列表,存储在files中,然后将数据中的info字段的第一个,也就是info[0] 绑定给文件下拉选择的选项,作为name

text和file的参数区别

后端返回文件列表的数据格式如下:
在这里插入图片描述
之前定义的params是一个列表,如下

params = [name,value] # 2部分组成,name和value,
# 而这个value,需要区分text和file
# 1.当选择text,value只有一个文本值
params = [name,[text_value]]

# 2.当选择file,value则包含3部分
params = [name,[file_name,file_type,file_url]]

所以这里需要区分一下选择Text和选择File

 <el-select @change="selectType($event, index)" v-model="paramsType[index]" placeholder="参数类型" size="small" style="width: 100%;">
   <el-option label="Text" value="text"/>
   <el-option label="File" value="file"/>
 </el-select>
const selectType = (val, index) => {
  if (val === 'file') {
    params.value[index][1] = ['', '', ''];
  } else {
    params.value[index][1] = '';
  }
};
下拉选项绑定File

在下拉选择时,绑定change函数,如果选择file,那参数就有3个部分组成.

 <el-select v-else @change="selectFile($event, index)" v-model="item[1][0]" size="small"
            placeholder="选择已有文件" style="width: 100%;">
   <el-option v-for="item in files" :label="item.info[0]" :value="item.info[0]"/>
 </el-select>
const files = ref([]);

const getAllFile = async () => {
  // 获取文件列表
  const response = await http.pro.getFiles();
  if (response.status === 200) {
    files.value = response.data;
  }
};

onMounted(() => {
if (props.modelValue.length > 0) {
    params.value = props.modelValue;
  } else {
    params.value = [
      ['', '']
    ];
  }
  getAllFile();
});

在这里插入图片描述

2. 右边的上传及预览部分

<el-col :span="9">
      <el-card style="padding: 0;">
        <el-upload class="upload-demo" :action="uploadApi" :on-success="uploadSuccess" :on-error="uploadError" :show-file-list="false" name="file" >
          <el-button type="primary" plain size="small">上传文件</el-button>
        </el-upload>
        <el-table :data="files" style="width: 100%" size="small" height="200px">
          <el-table-column label="已有文件">
            <template #default="scope">
              <el-tag type="success">{{ scope.row.info[0] }}</el-tag>
            </template>

          </el-table-column>
          <el-table-column label="文件类型">
            <template #default="scope">
              <el-tag type="info">{{ scope.row.info[1] }}</el-tag>
            </template>
          </el-table-column>
        </el-table>
        <div>
          。。。图片和视频展示
        </div>

      </el-card>
    </el-col>

一个上传按钮,使用el-upload,然后一个表单展示组件,一个iframe用于显示已有的文件。

el-upload

https://element-plus.org/zh-CN/component/upload.html

在这里插入图片描述
添加请求上传的url

cosnt uploadApi = request.defaults.baseURL + `/api/testFile/files/`

绑定成功和失败的事件,给出提醒就行了。

const uploadSuccess = (response) => {
  ElMessage({
    type: 'success',
    message: '文件上传成功!',
    duration: 2000
  });
  getAllFile();
};

const uploadError = (error) => {
  ElMessage({
    type: 'error',
    message: error,
    duration: 2000
  });
};

此时选择文件就能直接调用接口,上传了。
在这里插入图片描述

el-table

 <el-table :data="files" style="width: 100%" size="small" height="200px">
          <el-table-column label="已有文件" show-overflow-tooltip>
            <template #default="scope">
              <el-tag type="success">{{ scope.row.info[0] }}</el-tag>
            </template>

          </el-table-column>
          <el-table-column label="文件类型">
            <template #default="scope">
              <el-tag type="info">{{ scope.row.info[1] }}</el-tag>
            </template>
          </el-table-column>
</el-table>

表单部分,与之前下拉选择时一致。内容从files读取,显示名字的地方,超长,则悬浮展示全称。

单个文件数据

{
  "id": 5,
  "info": [
    "procard.jpg",
    "image/jpeg",
    "https://testapi-13xxxx-chengdu.myqcloud.com/procard.jpg "
  ],
  "file": "procard.jpg"
}

之前也看过,文件类型数据info定义时含3个字段,名字,图片,和存储地址(使用了腾讯云的对象存储)。
所以显示文件名是scope.row.info[0] ,文件类型是scope.row.info[1]

图片与视频预览展示

点击文件名,预览一下图片/视频。给文件名增加点击事件,把info传过去

<el-tag type="success" @click="viewfile( scope.row.info)">{{ scope.row.info[0] }}</el-tag>

点击后,判断点击的是图片还是视频,用不同的标签进行渲染展示

const fileType = ref('image')
const mediaIframe = ref(null);

const viewFile = (info) => {
  mediaIframe.value = info[2];
  const type = info[1].toLowerCase().split('/')[0];
  console.log(type)
  if (type === 'image') {
    fileType.value = 'image'
  } else {
    fileType.value = 'video'
  }
};
<div v-if="mediaIframe">
          <img v-if="fileType === 'image'" @click="showFullImg" :src="mediaIframe" style="width: 100%; height: 200px;"
               alt="预览">
          <video
              v-else
              :src="mediaIframe"
              @click="showFullImg"
              controls
              preload="metadata"
              controlsList="nodownload"
              style="width: 100%; height: 200px;">
            您的浏览器不支持视频播放
          </video>
 </div>

        <!-- 添加Dialog组件,用于大屏展示 -->
        <el-dialog v-if="fileType==='image'" v-model="dialogVisible" title="图片预览" width="80%">
          <img :src="mediaIframe" style="width: 100%; height: auto;" alt="完整图片">
        </el-dialog>
        <el-dialog v-else v-model="dialogVisible" title="视频预览"  :width="dialogWidth"  ref="videoDialog">
          <video
              :src="mediaIframe"
              style="width: 100%; height:500px;"
              controls
              preload="auto"
              controlsList="nodownload"
              @loadedmetadata="setDialogWidth"
              autoplay
          >
            您的浏览器不支持视频播放
          </video>
        </el-dialog>


const dialogVisible = ref(false);
const dialogWidth = ref('80%'); // 默认宽度
const videoDialog = ref(null); // 对话框的 ref

//点击全屏展示
const showFullImg = () => {
  dialogVisible.value = true; // 显示Dialog
};

// 根据视频本身大小,来设置弹窗宽高。代码用cursor生成的,能用就行
const setDialogWidth = (event) => {
  const video = event.target;
  const videoWidth = video.videoWidth;
  const videoHeight = video.videoHeight;
  const maxWidth = window.innerWidth * 0.8; // 最大宽度为视口宽度的80%
  const maxHeight = window.innerHeight * 0.8; // 最大高度为视口高度的80%

  let dialogWidthValue = (videoWidth / videoHeight) * maxHeight;
  if (dialogWidthValue > maxWidth) {
    dialogWidthValue = maxWidth;
  }

  dialogWidth.value = `${dialogWidthValue}px`;
};
// 添加视频相关样式 (AI生成的,直接复制的)
video {
  object-fit: contain;
  background: #000; /* 添加黑色背景 */
  cursor: pointer;

  &::-webkit-media-controls-download-button {
    display: none; /* 隐藏 Chrome 下载按钮 */
  }

  &::-webkit-media-controls-enclosure {
    overflow: hidden;
  }
}

// 优化弹窗中的视频显示
.el-dialog {
  .el-dialog__body {
    padding: 10px;
    background: #000;

    video {
      max-height: 70vh;
      margin: 0 auto;
      display: block;
    }
  }
}

在这里插入图片描述
点击全屏展示:
在这里插入图片描述
到此,整个请求体部分就完成了
在这里插入图片描述

三、总结

主要还是elment组件的使用,用到了el-upload,el-table,el-row,el-select等等。
video展示那块还得是AI,真是一边写,一边问。才得到结果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2335960.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

小程序css实现容器内 数据滚动 无缝衔接 点击暂停

<view class"gundongBox"><!-- 滚动展示信息的模块 --><image class"imgWid" :src"imgurlgundong.png" mode"widthFix"></image><view class"gundongView"><view class"container&qu…

【力扣】day1

文章目录 27.移除元素26. 删除有序数组的重复项 27.移除元素 26. 删除有序数组的重复项 我们仔细看一下这两道题的最后的返回值,为什么第一题返回slow 而第二题返回slow1 最后的返回值该如何返回绝对不是凭感觉,我们自己分析一下第一个slow,从0位置开始, 遇到val值就开始和fas…

图像预处理-色彩空间补充,灰度化与二值化

一.图像色彩空间转换 1.1 HSV颜色空间 HSV颜色空间使用色调&#xff08;Hue&#xff09;、饱和度&#xff08;Saturation&#xff09;和亮度&#xff08;Value&#xff09;三个参数来表示颜色 一般对颜色空间的图像进行有效处理都是在HSV空间进行的&#xff0c;然后对于基本…

项目交接时信息遗漏,如何预防

项目交接时&#xff0c;信息遗漏可能导致任务延误、质量下降和团队混乱&#xff0c;因此&#xff0c;建立系统化的交接流程和使用专业的工具是防止信息遗漏的有效策略。交接过程中的信息丢失往往源自沟通不畅、文档不完整或者责任不明确等问题&#xff0c;这不仅影响项目的顺利…

【AI量化第24篇】KhQuant 策略框架深度解析:让策略开发回归本质——基于miniQMT的量化交易回测系统开发实记

我是Mr.看海&#xff0c;我在尝试用信号处理的知识积累和思考方式做量化交易&#xff0c;应用深度学习和AI实现股票自动交易&#xff0c;目的是实现财务自由~ 目前我正在开发基于miniQMT的量化交易系统——看海量化交易系统。 本篇要讲到量化的核心了——策略。说白了每个投资者…

向量数据库Qdrant 安装 不使用docker

一、导读 环境&#xff1a;Ubuntu 24.04、Windows 10、WSL 2、Qdrant 1.13.4 背景&#xff1a;换了新工作&#xff0c;使用qdrant作为向量库&#xff0c;需要不使用docker安装 时间&#xff1a;20250415 说明&#xff1a;初入职&#xff0c;不了解&#xff0c;暂且记下 二、…

微电网与分布式能源:智能配电技术的场景化落地

安科瑞顾强 随着数字化转型与能源革命的加速推进&#xff0c;电力系统正经历从传统模式向智能化、网络化方向的深刻变革。用户侧的智能配电与智能用电技术作为这一变革的核心驱动力&#xff0c;正在重塑电力行业的生态格局。本文将从技术架构、应用场景及未来趋势等维度&#…

Web三漏洞学习(其一:文件上传漏洞)

靶场:云曦历年考核题 一、文件上传 在此之前先准备一个一句话木马 将其命名为muma.txt 23年秋期末考 来给师兄上个马 打开环境以后直接上传muma.txt&#xff0c;出现js弹窗&#xff0c;说明有前端验证 提示只能上传.png .jpg 和 .gif文件&#xff0c;那就把muma.txt的后缀…

Web三漏洞学习(其二:sql注入)

靶场&#xff1a;NSSCTF 、云曦历年考核题 二、sql注入 NSSCTF 【SWPUCTF 2021 新生赛】easy_sql 这题虽然之前做过&#xff0c;但为了学习sql&#xff0c;整理一下就再写一次 打开以后是杰哥的界面 注意到html网页标题的名称是 “参数是wllm” 那就传参数值试一试 首先判…

KrillinAI:视频跨语言传播的一站式AI解决方案

引言 在全球内容创作领域&#xff0c;跨语言传播一直是内容创作者面临的巨大挑战。传统的视频本地化流程繁琐&#xff0c;涉及多个环节和工具&#xff0c;不仅耗时耗力&#xff0c;还常常面临质量不稳定的问题。随着大语言模型(LLM)技术的迅猛发展&#xff0c;一款名为Krillin…

gravity`(控制 View 内部内容的对齐方式)

文章目录 **1. 常用取值****示例** **2. layout_gravity&#xff08;控制 View 在父容器中的对齐方式&#xff09;****常用取值****示例** **3. gravity vs layout_gravity 对比****4. 注意事项****5. 总结** 作用对象&#xff1a;当前 View 的内部内容&#xff08;如 TextView…

gitdiagram源码架构分析

https://github.com/ahmedkhaleel2004/gitdiagram 整体架构分析 前端请求入口&#xff1a; 后端对应接口&#xff1a; 后端调试 后端调试&#xff1a;会提示api_key失败的问题&#xff1a; 有两种方法解决&#xff1a; 1、注释掉下面的行代码&#xff1b; 方法二&#xff1…

蓝光三维扫描:汽车冲压模具与钣金件全尺寸检测的精准解决方案

随着汽车市场竞争日趋激烈&#xff0c;新车型开发周期缩短&#xff0c;安全性能要求提高&#xff0c;车身结构愈加复杂。白车身由多达上百个具有复杂空间型面的钣金件&#xff0c;通过一系列工装装配、焊接而成。 钣金件尺寸精度是白车身装配精度的基础。采用新拓三维XTOM蓝光…

深度学习占用大量内存空间解决办法

应该是缓存的问题&#xff0c;关机重启内存多了10G&#xff0c;暂时没找到别的方法 重启前 关机重启后

Matlab绘制函数方程图形

Matlab绘制函数方程图形&#xff1a; 多项式计算: polyval 函数 Values of Polynomials: polyval ( ) 绘制方程式图形&#xff1a; 代码如下&#xff1a; >> a[9,-5,3,7]; x-2:0.01:5; fpolyval(a,x); plot(x,f,LineWidth,2); xlabel(x); ylabel(f(x))…

电视盒子 刷armbian

参考 中兴电视盒子中兴B860AV3.2-M刷Armbian新手级教程-CSDN博客 1.刷安卓9 带root版本 a. 下载安卓线刷包 链接&#xff1a;https://pan.baidu.com/s/1hz87_ld2lJea0gYjeoHQ8A?pwdd7as 提取码&#xff1a;d7as b.拆机短接 3.安装usbburning工具 使用方法 &#xff0c;…

AI应用开发之扣子第一课-夸夸机器人

首先&#xff0c;进入官网&#xff1a;点击跳转至扣子。 1.创建智能体 登录进网站后&#xff0c;点击左上角&#xff0b;图标&#xff0c;创建智能体&#xff0c;输入智能体名称、功能介绍 2.输入智能体提示词 在“人设与回复逻辑”输入以下内容&#xff1a; # 角色 你是一…

【计算机网络实践】(十二)大学校园网综合项目设计

本系列包含&#xff1a; &#xff08;一&#xff09;以太网帧分析与网际互联协议报文结构分析 &#xff08;二&#xff09;地址解析协议分析与传输控制协议特性分析 &#xff08;三&#xff09;交换机的基本操作、配置、 虚拟局域网配置和应用 &#xff08;四&#xff09;交…

uniapp小程序位置授权弹框与隐私协议耦合(合而为一)(只在真机上有用,模拟器会分开弹 )

注意&#xff1a; 只在真机上有用&#xff0c;模拟器会分开弹 效果图&#xff1a; 模拟器效果图&#xff08;授权框跟隐私政策会分开弹&#xff0c;先弹隐私政策&#xff0c;同意再弹授权弹框&#xff09;&#xff1a; manifest-template.json配置&#xff08; "__usePr…

【星闪模组开发板WS8204SLEBLEModule】星闪数据收发测试

目录 开发板简介 串口设置 主从模式设置 AT命令数据发送 透传模式数据发送 结语 本文首发于《电子产品世界》论坛&#xff1a;【星闪模组开发板WS8204SLE&BLEModule】星闪数据收发测试-电子产品世界论坛https://forum.eepw.com.cn/thread/392011/1 感谢eepw论坛和成…