微信原生实现一个简易的图片上传功能

一、实现原理

  1. wx.showActionSheet():显示操作菜单,选择是从相册选择还是相机拍摄照片
  2. wx.chooseImage():从本地相册选择图片或使用相机拍照。
  3. wx.uploadFile():将本地资源上传到服务器。客户端发起一个 HTTPS POST 请求,其中 content-type 为 multipart/form-data。
  4. wx.previewMedia(): 预览图片和视频。

二、代码

upload.wxml

<view class="study-title">图片上传原理</view>
<view class="show-img-box"><view class="img-item-box" wx:for="{{imgList}}" wx:key="*this" data-src="{{item}}" data-src-list="{{imgList}}" bindtap="clickImg"><image class="img-item" src="{{item}}" /></view><view class="upload" bindtap="chooseImgType"><view class="img-upload"></view></view>
</view>

upload.wxss

/* pages/upload/upload.wxss */
.study-title {width: 100vw;margin: 50rpx 0;font-size: 40rpx;font-weight: 800;text-align: center;
}
.show-img-box {width: 600rpx;display: flex;flex-wrap: wrap;margin: 0 auto;
}.img-item-box {width: 184rpx;height: 184rpx;margin: 4px;background-color: #ccc;
}.img-item {width: 184rpx;height: 184rpx;
}
.upload {margin: 4px;width: 184rpx;height: 184rpx;background: rgba(203, 224, 208, 0.5);border-radius: 5rpx;display: flex;align-items: center;justify-content: center;
}
.img-upload {width: 120rpx;height: 120rpx;background-image: url(https://pro-core.babycdn.com/2021/aosmith/lottery/images2020/watersystem/case/robot/img_upload.png);background-repeat: no-repeat;background-size: cover;
}

upload.js

// pages/upload/upload.js
Page({/*** 页面的初始数据*/data: {imgList: [],  // 由于没有可用的服务器域名,因此定义此数据用于展示上传的图片,以演示图片预览功能imgFilePaths: [], // 上传的图片存放路径,有可用的服务器域名用此数据渲染showSelect: false, // 是否显示选择框host: "https://5blog.com/Api", // 服务器域名,此处为错误域名},// 弹出操作菜单,选择获取图片的方式chooseImgType() {// 显示操作菜单wx.showActionSheet({itemList: ["从相册选择", "拍照"],success: (res) => {if (res.tapIndex == 0) {this.chooseImg("album");} else if (res.tapIndex == 1) {this.chooseImg("camera");}},});},// 选择图片chooseImg(type) {let { imgFilePaths } = this.data;wx.chooseImage({// 从本地相册选择照片或使用相机拍照count: 9, // 最多可以选择的图片张数, 默认9sizeType: ["original", "compressed"], // 所选图片的尺寸,默认原图和压缩图都可以sourceType: [type], // 选择图片的来源,默认相册和相机都可以success: async (res) => {// 接口调用成功的回调// console.log("res", res);// res.tempFilePaths是临时文件路径数组,数组内的元素可以直接作为src使用const tempFilePaths = res.tempFilePaths;this.setData({imgList: res.tempFilePaths,});let tempLength = 9 - imgFilePaths.length;let tempFilePaths_ = tempFilePaths.splice(0, tempLength);// 得到所有上传成功后的图片url组成的数组let imgUrlArr = await Promise.all(// 实现上传所有图片到服务器tempFilePaths_.map((item, index) => {// 返回每张图片的上传结果return this.updateImg(item, index);}));console.log("imgUrlArr", imgUrlArr);// 根据需求补充其他内容},fail: (err) => {console.log(type);// 接口调用失败的回调console.log("图片选取上传错误", err);},complete: () => {// 接口调用结束的回调(调用成功、失败都会执行)},});},// 实现将单张图片上传服务器,上传成功返回图片url,上传失败返回falseupdateImg(src, index = 0) {wx.showLoading({title: "上传中...",mask: true,});// 将本地资源上传到服务器接口,客户端发起一个post请求// 其中content-type为multipart/form-datareturn new Promise((resolve, reject) => {wx.uploadFile({url: this.data.host + "/Attach/Index/upload", // 开发者服务器地址filePath: src, // 要上传文件资源的路径(本地路径)header: {"content-type": "multipart/form-data", // 默认值},name: "img", // 文件对应的key,开发者在服务端通过这个key获取文件的二进制内容formData: {// http请求中其他额外的form datatype: "image",index: index,},// 上传成功的回调success: function (res) {console.log("res", res);if (res && res.data && !res.data.error) {let img = JSON.parse(res.data);resolve(img.data);} else {wx.showToast({title: "图片提交失败",icon: "none",duration: 1500,});resolve(false);}},complete: function (res) {wx.hideLoading();},});});},// 实现图片预览clickImg(e) {let src = e.currentTarget.dataset.src;let sources = e.currentTarget.dataset.srcList;console.log(sources);sources = sources.map((item) => {return {url: item, // 链接type: "image", // 默认类型是图片};});// 预览图片和视频接口wx.previewMedia({sources: sources,});},
});

三、效果演示

这里进行了真机调试以演示以上代码的实际运行效果。
此处选择了从相册选择
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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

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

相关文章

项目实战Qt网盘系统

背景&#xff1a;随着时代的发展&#xff0c;业务数据量的剧增及移动办公需求&#xff0c;人们对内存的需求越来越强&#xff0c;传统的存储产品&#xff0c;在容量及携带型日益不能满足人工的工作需求&#xff0c;网盘再此背景下应运而生。网盘是能够提供文件同步&#xff0c;…

回归预测 | MATLAB实现GRU(门控循环单元)多输入单输出(不调用工具箱函数)

回归预测 | MATLAB实现GRU(门控循环单元)多输入单输出(不调用工具箱函数) 文章目录 回归预测 | MATLAB实现GRU(门控循环单元)多输入单输出(不调用工具箱函数)预测效果基本介绍程序设计参考资料 预测效果 基本介绍 GRU神经网络是LSTM神经网络的一种变体&#xff0c;LSTM 神经网 …

Ubuntu 考虑采用新的 “统一默认安装 (unified default install)”

导读Ubuntu安装程序中的 “最小化安装” (Minimal installation) 是该发行版多年来最受欢迎的功能之一。 当用户选择 Ubuntu 的 “最小化安装” 选项时&#xff0c;可以在安装更少的预装应用程序情况下&#xff0c;获得完整、功能齐全的 Ubuntu 系统。 但这个功能可能要被砍掉…

个人博客系统(二)

该博客系统共有八个页面,即注册页面、登录页面、添加文章页面、修改文章页面、我的博客列表页面、主页、查看文章详情页面、个人中心页面。 1 注册页面 该页面如图所示: 首先,要先判断注册的用户名、密码、确认密码以及验证码是否为空,若有一个为空,点击提交,则会提醒 …

文献阅读:MathPrompter: Mathematical Reasoning using Large Language Models

文献阅读&#xff1a;MathPrompter: Mathematical Reasoning using Large Language Models 1. 内容简介2. 方法细节3. 实验内容4. 结论&思考 文献链接&#xff1a;https://arxiv.org/abs/2303.05398 1. 内容简介 这篇文章是今年3月份的时候微软提出的一篇工作&#xff0…

【云原生】k8s安全机制

前言 Kubernetes 作为一个分布式集群的管理工具&#xff0c;保证集群的安全性是其一个重要的任务。API Server 是集群内部各个组件通信的中介&#xff0c; 也是外部控制的入口。所以 Kubernetes 的安全机制基本就是围绕保护 API Server 来设计的。 比如 kubectl 如果想向 API…

工欲善其事,必先利其器之—react-native-debugger调试react native应用

调试react应用通常利用chrome的inspector的功能和两个最常用的扩展 1、React Developer Tools &#xff08;主要用于debug组件结构) 2、Redux DevTools &#xff08;主要用于debug redux store的数据&#xff09; 对于react native应用&#xff0c;我们一般就使用react-nativ…

Java项目查询统计表中各状态数量

框架&#xff1a;SpringBoot&#xff0c;Mybatis&#xff1b;数据库&#xff1a;MySQL 表中设计2个状态字段&#xff0c;每个字段有3种状态&#xff0c;统计这6个状态各自的数量 sql查询语句及结果如图 SQL&#xff1a; SELECT SUM(CASE WHEN A0 THEN 1 ELSE 0 END) AS A0…

数据分析的iloc和loc功能

大家好&#xff0c;在处理大型数据集时&#xff0c;使用有效的数据操作和提取技术是必要的。Pandas数据分析库提供了强大的工具&#xff0c;用于处理结构化数据&#xff0c;包括使用iloc和loc函数访问和修改DataFrame元素的能力。在本文中&#xff0c;我们将探讨iloc和loc之间的…

论文笔记--OpenPrompt: An Open-source Framework for Prompt-learning

论文笔记--OpenPrompt: An Open-source Framework for Prompt-learning 1. 文章简介2. 文章概括3 文章重点技术4. 文章亮点5. 原文传送门 1. 文章简介 标题&#xff1a;OpenPrompt: An Open-source Framework for Prompt-learning作者&#xff1a;Ning Ding, Shengding Hu, We…

短视频seo矩阵系统源码开发部署

目录 短视频矩阵源码部署步骤简单易懂&#xff0c;开发者只需按照以下几个步骤进行操作&#xff1a; 代码展示---seo关键词分析 开发要点&#xff1a; 代码展示如下&#xff1a; 开发部署注意事项&#xff1a; 说明&#xff1a;本开发文档适用于短视频seo矩阵系统源码开发…

PostgreSQL考试难不难 ?

当涉及到PostgreSQL考试的详细难度&#xff0c;以下是一些可能涉及的主题和考点&#xff0c;这些主题在不同的考试中可能有所不同&#xff1a; 1.数据库基础知识&#xff1a;数据库的基本概念、关系型数据库模型、表、字段、主键、外键等。 2.SQL语言&#xff1a;对SQL语言的掌…

ACME申请SSL证书

1.开放443端口 firewall-cmd --permanent --add-port443/tcp # 开放443端口 firewall-cmd --reload # 重启防火墙(修改配置后要重启防火墙)2.安装ACME # 安装acme curl https://get.acme.sh | sh -s email你的邮箱地址 # 别名 alias acme.sh~/.acme.sh/acme.sh3.使用ACME申请…

攻防世界-web-easytornado

题目描述&#xff1a;Tornado 框架。打开链接是一个简单的界面 1. 思路分析 看到有个/flag.txt&#xff0c;我们点击进去看下 发现传入了两个参数&#xff0c;一个是filename&#xff0c;还有一个是filehash 看到里面的内容&#xff0c;提示我们真正的flag在 /flllllllllllla…

【自监督预训练 2023】MCL

【自监督预训练 2023】MCL 论文题目&#xff1a;Multi-Level Contrastive Learning for Dense Prediction Task 中文题目&#xff1a;稠密预测任务的多级对比学习 论文链接&#xff1a;https://arxiv.org/abs/2304.02010 论文代码&#xff1a;https://github.com/GuoQiushan/MC…

Unity视角拉近时物体缺失的问题处理

在Unity的开发过程中&#xff0c;我们可能会遇到以下情况&#xff1a; 就是在场景的不断编辑中&#xff0c;突然又一次打开场景&#xff0c;再拉近或拉远场景视角时&#xff0c;会出现场景中的对象会显示不全的问题。 出现了这样的情况会让场景的预览很不友好。 出现这个问题的…

rust

文章目录 rustCargoCreating a rust project How to Debug Rust Programs using VSCodebasic debuggingHow to pass arguments in Rust debugging with VS Code. References rust Cargo Cargo is a package management tool used for downloading, compiling, updating, and …

行为型模式 - 命令模式

概述 日常生活中&#xff0c;我们出去吃饭都会遇到下面的场景。 定义&#xff1a; 将一个请求封装为一个对象&#xff0c;使发出请求的责任和执行请求的责任分割开。这样两者之间通过命令对象进行沟通&#xff0c;这样方便将命令对象进行存储、传递、调用、增加与管理。 结构 …

Hugging News #0717: 开源大模型榜单更新、音频 Transformers 课程完成发布!

每一周&#xff0c;我们的同事都会向社区的成员们发布一些关于 Hugging Face 相关的更新&#xff0c;包括我们的产品和平台更新、社区活动、学习资源和内容更新、开源库和模型更新等&#xff0c;我们将其称之为「Hugging News」。本期 Hugging News 有哪些有趣的消息&#xff0…

nacos注册中心+Ribbon负载均衡+完成openfeign的调用(超详细步骤)

目录 1.注册中心 1.1.nacos注册中心 1.2. 微服务注册和拉取注册中心的内容 2.3.修改订单微服务的代码 3.负载均衡组件 3.1.什么是负载均衡 3.2.什么是Ribbon 3.3.Ribbon 的主要作用 3.4.Ribbon提供的负载均衡策略 4.openfeign完成服务调用 4.1.什么是OpenFeign 4.2…