vue3+ts+flask+websocket实现实时异物检测

文章目录

1.学习目的

最近有个需求,界面需要有两种检测方式,一种是静态的,也就是使用普通的flask接口即可,一种是利用前后端建立websocket通信,实现数据实时传输,然后我们后端检测模型实时进行视频检测,这样一来,我们就可以方便的进行检测见面展示,以及后期的语音播报等下游任务。

2.技术栈

  • 前端:vue3+ts
  • 后端:flask/fastAPI中的websocket

3.框架一些前置知识以及bug处理

图1 vue3主程序入口

图2 语法校验需要添加的rules

如上图,HelloWorld报错,提示信息实际上是说这个组件没有默认导出,但是vue3新特性明确指出,setup语法糖是默认导出的,再仔细检查,vetur语法检查存在bug,所以我们不必太过理会。

上图是一些ts配置,可以配一下。

对vue不太了解的话,建议去官网学习

通过这个,可以把传统的按钮嵌套icon进行封装,直接调用elementUI即可很好的实现这种带log的按钮

4.具体实现

  • 利用webpack搭建vue3项目
  • npm install
    - 利用npm安装elementui库
    - vue3--main.ts中引入elementUI

    注意这里是全局引入,如果需要轻量化引入,可以参考elementUI官网进行处理,这里不再重复说明。

    使用icon需要额外下载这个包,不然看不见那些icon

后端返回数据的时候,还是采用mimeType比较好,必须设置好前后端返回数据类型格式。必须设置好相应的前后端交互数据类型。
文件上传操作

typescript 复制代码
</template>
 <input type="file" @change="onFileChange" />
</template>
<!-- 编写界面逻辑js -->
 <script setup lang='ts'>
const onFileChange = (event: Event) => {
  const target = event.target as HTMLInputElement;
  if (target.files && target.files[0]) {
    selectedFile.value = target.files[0];
  }
};
</script>

4.结果展示

5.总结

本次改进比较简单,关注我,继续学习前端知识~

相关推荐
再__努力1点1 天前
【11】特征检测与匹配:AKAZE特征算法详解与实现
人工智能·python·opencv·算法·计算机视觉·特征提取
麦麦大数据1 天前
F046 新闻推荐可视化大数据系统vue3+flask+neo4j
python·flask·vue3·知识图谱·neo4j·推荐算法
MediaTea1 天前
Python 第三方库:Markdown(将文本渲染为 HTML)
开发语言·前端·python·html
2302_815906671 天前
石头剪刀布小游戏开发
python
程序员爱钓鱼1 天前
Python 综合项目实战:学生成绩管理系统(命令行版)
后端·python·ipython
Brsentibi1 天前
基于python代码自动生成关于建筑安全检测的报告
python·microsoft
程序员爱钓鱼1 天前
REST API 与前后端交互:让应用真正跑起来
后端·python·ipython
gCode Teacher 格码致知1 天前
Python基础教学:Python的openpyxl和python-docx模块结合Excel和Word模板进行数据写入-由Deepseek产生
python·excel
Destiny_where1 天前
Agent平台-RAGFlow(2)-源码安装
python·ai
molunnnn1 天前
第四章 Agent的几种经典范式
开发语言·python