当前位置: 首页 > news >正文

uniapp上传功能用uni-file-picker实现

在这里插入图片描述

文章目录

  • html代码
  • 功能实现
  • css样式代码


html代码

        <uni-file-picker@select="onFileSelected"@cancel="onFilePickerCancel"limit="1"class="weightPage-upload-but"file-mediatype="image"></uni-file-picker><imageclass="weightPage-item-upload-img"v-if="weightData.img_url":src="weightData.img_url"mode=""></image><imageclass="weightPage-item-upload-img"v-elsesrc="@/static/checkDetails/upload.png"mode=""></image>

用image覆盖,就能实现完全自定义上传样式的功能(也能用其他的覆盖)
上传前:在这里插入图片描述

上传后:在这里插入图片描述

功能实现

  data() {return {weightData: {img_url: "",},};},methods: {onFileSelected(e) {// 获取选中的文件路径const filePath = e.tempFiles[0].url;console.log(filePath);// 调用上传图片的方法this.uploadImage(filePath);},async uploadImage(filePath) {try {let formData = new FormData();formData.append("file", {url: filePath,name: "image.jpg",type: "image/jpeg",});// 转换为普通 Objectconst formDataObj = {};for (let [key, value] of formData.entries()) {formDataObj[key] = value;}/*#ifdef MP-WEIXIN*/// 从微信小程序的本地缓存中取出 tokenlet wxToken = wx.getStorageSync("token");let wxbaseURL = wx.getStorageSync("baseURL");// 检查是否成功获取到值if (wxToken) {uni.uploadFile({url: `${wxbaseURL}...`, //需要传图片的后台接口filePath: filePath, // 上传图片 通过uni-app的uni-file-picker组件 函数返回name: "image", //文件名字header: {Authorization: "Bearer " + wxToken,},formData: formDataObj,success: (res) => {const { data } = JSON.parse(res.data);console.log(data);this.weightData.img_url = data.url;uni.showToast({title: "图片上传成功",icon: "success",duration: 2000, // 提示持续时间,单位为毫秒});},fail: (e) => {console.log(e);},});}/*#endif*//*#ifdef H5*/let Token = localStorage.getItem("token");let baseURL = localStorage.getItem("baseURL");// 检查是否成功获取到值if (Token) {uni.uploadFile({url: `${baseURL}...`, //需要传图片的后台接口filePath: filePath, // 上传图片 通过uni-app的uni-file-picker组件 函数返回name: "image", //文件名字header: {Authorization: "Bearer " + Token,},formData: formDataObj,success: (res) => {console.log(JSON.parse(res.data));const { data } = JSON.parse(res.data);console.log(data);this.weightData.img_url = data.url;uni.showToast({title: "图片上传成功",icon: "success",duration: 2000, // 提示持续时间,单位为毫秒});},fail: (e) => {console.log(e);},});}/*#endif*/// 可以添加上传进度监听等额外逻辑} catch (error) {console.error("上传图片时发生错误", error);}},onFilePickerCancel() {console.log("取消选择");// 可以在这里处理取消选择的逻辑},},

css样式代码

隐藏样式的重点是 opacity: 0;

    .weightPage-upload-but {position: absolute;width: 279px;height: 100px;z-index: 1;left: 0px;opacity: 0;padding: 10px;}.weightPage-item-upload-img {width: 80px;height: 78px;border-radius: 10px;}.weightPage-item-upload-text {font-size: 12px;font-weight: 500;line-height: 19px;color: rgba(153, 153, 153, 1);flex: 1;padding: 10px;}

您好,我是肥晨。
欢迎关注我获取前端学习资源,日常分享技术变革,生存法则;行业内幕,洞察先机。

http://www.lryc.cn/news/403545.html

相关文章:

  • 【PPT笔记】1-3节 | 默认设置/快捷键/合并形状
  • Qt中的高分辨率及缩放处理
  • 电机泵盖机器人打磨去毛刺,选德国进口高精度主轴
  • Android init.rc各阶段的定义和功能
  • .net dataexcel 脚本公式 函数源码
  • HarmonyOS ArkUi @CustomDialog 和promptAction.openCustomDialog踩坑以及如何选择
  • Python面试题:详细讲解Python的多线程与多进程编程问题
  • 前端Canvas入门——用canvas写五子棋?
  • [PaddlePaddle飞桨] PaddleDetection-通用目标检测-小模型部署
  • Golang | Leetcode Golang题解之第239题滑动窗口最大值
  • 深度解析:在 React 中实现类似 Vue 的 KeepAlive 组件
  • 2024-7-20 IT新闻
  • 前端组件化开发:以Vue自定义底部操作栏组件为例
  • 11.斑马纹列表 为没有文本的链接设置样式
  • 【算法】跳跃游戏II
  • 学习大数据DAY20 Linux环境配置与Linux基本指令
  • 达梦+flowable改造
  • 【乐吾乐2D可视化组态编辑器】消息
  • Qt创建列表,通过外部按钮控制列表的选中下移、上移以及左侧图标的显现
  • svn不能记住密码,反复弹出GNOME,自动重置svn.simple文件
  • 对称加密与非对称加密
  • 03 Git的基本使用
  • 【Linux】将IDEA项目部署到云服务器上,让其成为后台进程(保姆级教学,满满的干货~~)
  • IDEA的断点调试(Debug)
  • 部署django
  • Android Framework学习笔记(4)----Zygote进程
  • 澎湃算力 玩转AI 华为昇腾AI开发板——香橙派OriengePi AiPro边缘计算案例评测
  • <数据集>铁轨缺陷检测数据集<目标检测>
  • 第2章 矩阵
  • 抖音seo短视频矩阵源码系统开发搭建----开源+二次开发