位置: IT常识 - 正文

uniapp、uview——图片上传(单图上传、多图上传、多组照片上传、图片回显)(uniapp+uview)

编辑:rootadmin
uniapp、uview——图片上传(单图上传、多图上传、多组照片上传、图片回显) 一、简介

推荐整理分享uniapp、uview——图片上传(单图上传、多图上传、多组照片上传、图片回显)(uniapp+uview),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:uni-app app.vue,uniapp和uview,uniapp+uview,uniapp使用weui,uniapp v-for,uniapp使用weui,uniapp v-for,uniapp+uview,内容如对您有帮助,希望把文章链接给更多的朋友!

uView组件的上传功能,单图上传、多图上传等。 官方文档地址: https://www.uviewui.com/components/upload.html

二、步骤(一)单图上传1.效果演示:

只能上传一张,选完之后,上传的按钮消失,当然,如果图片不合适,删掉再换一张,但就是只能上传一张。

2.代码:<template><view class="content"><!-- 上传图片 --><u-upload :fileList="fileList1" @afterRead="afterRead" @delete="deletePic" name="1" :multiple="false" :maxCount="1" width="112rpx" height="109rpx" :deletable="true" :previewImage="true"> <!-- 这张图片就是自定义的图片,地址填写自己本地的就行 --><image src="/static/function/uploadImg.png" mode="widthFix" style="width: 112rpx;height: 110rpx;"></image></u-upload></view></template><script>export default {data() {return {// 上传图片fileList1: [],}},onLoad() {},methods: { //删除图片deletePic(e) {console.log(e);this[`fileList${e.name}`].splice(e.index, 1)},// 新增图片async afterRead(event) {console.log(event)// 当设置 mutiple 为 true 时, file 为数组格式,否则为对象格式let lists = [].concat(event.file)let fileListLen = this[`fileList${event.name}`].lengthlists.map((item) => {this[`fileList${event.name}`].push({...item,status: 'uploading',message: '上传中'})})for (let i = 0; i < lists.length; i++) {const result = await this.uploadFilePromise(lists[i].url)let item = this[`fileList${event.name}`][fileListLen]this[`fileList${event.name}`].splice(fileListLen, 1, Object.assign(item, {status: 'success',message: '',url: result}))fileListLen++}},//上传图片uploadFilePromise(url) {return new Promise((resolve, reject) => {let a = uni.uploadFile({//url: this.$common.domain+'/api/common/upload', // 仅为示例,非真实的接口地址url:'http://192.168.2.21:7001/upload', // 仅为示例,非真实的接口地址filePath: url,name: 'file',formData: {user: 'test'},success: (res) => {let data=JSON.parse(res.data) //最终传给的是字符串,这里需要转换格式resolve(data.data.url)}});})},}}</script><style lang="scss"></style>(二)多图上传1.效果演示:uniapp、uview——图片上传(单图上传、多图上传、多组照片上传、图片回显)(uniapp+uview)

可一次性选多张,我这里限制为两张,上传满两张则不会显示上传的logo。点击图片可预览。

2.代码:<template><view class="content"><!-- 上传图片 --><u-upload :fileList="fileList1" @afterRead="afterRead" @delete="deletePic" name="1" :multiple="true" :maxCount="2" width="112rpx" height="109rpx" :deletable="true" :previewImage="true"> <!-- 这张图片就是自定义的图片,地址填写自己本地的就行 --><image src="/static/function/uploadImg.png" mode="widthFix" style="width: 112rpx;height: 110rpx;"></image></u-upload></view></template><script>export default {data() {return {// 上传图片fileList1: [],}},onLoad() {},methods: { //删除图片deletePic(e) {console.log(e);this[`fileList${e.name}`].splice(e.index, 1)},// 新增图片async afterRead(event) {console.log(event)// 当设置 mutiple 为 true 时, file 为数组格式,否则为对象格式let lists = [].concat(event.file)let fileListLen = this[`fileList${event.name}`].lengthlists.map((item) => {this[`fileList${event.name}`].push({...item,status: 'uploading',message: '上传中'})})for (let i = 0; i < lists.length; i++) {const result = await this.uploadFilePromise(lists[i].url)let item = this[`fileList${event.name}`][fileListLen]this[`fileList${event.name}`].splice(fileListLen, 1, Object.assign(item, {status: 'success',message: '',url: result}))fileListLen++}},//上传图片uploadFilePromise(url) {return new Promise((resolve, reject) => {let a = uni.uploadFile({//url: this.$common.domain+'/api/common/upload', // 仅为示例,非真实的接口地址url:'http://192.168.2.21:7001/upload', // 仅为示例,非真实的接口地址filePath: url,name: 'file',formData: {user: 'test'},success: (res) => {setTimeout(() => {resolve(res.data.data)}, 1000)}});})},}}</script><style lang="scss"></style>三、其余补充

如果一个页面上有多处上传,操作也不是很复杂,大家都是共用同一个方法。 整体搬过来用即可。 请求接口的地方需要用join处理一下

getData() {let images=[]this.fileList1.forEach((item)=>{images.push(item.url)})this.$common.request('post', '/Coupon/addCoupon', {image:images.join(','),}).then(res => {if (res.code == 1) {this.$common.success(res.msg)setTimeout(()=>{this.$common.back()},1200)}})},新上传代码:(多图处理)<view class="imgBox"><u-upload :fileList="fileList" @afterRead="afterRead" @delete="deletePic" :multiple="true" :maxCount="9"><image :src="$common.image('/static/talentZone/addImg.png')" mode="aspectFill" class="fileImg"></image></u-upload></view>data() {return {// 图片列表fileList: []}},methods: {// 图片上传//删除图片deletePic(e) {console.log(e);this.fileList.splice(e.index, 1)},// 新增图片async afterRead(event) {// 当设置 mutiple 为 true 时, file 为数组格式,否则为对象格式let lists = [].concat(event.file)let fileListLen = this.fileList.lengthlists.map((item) => {this.fileList.push({...item,status: 'uploading',message: '上传中'})})for (let i = 0; i < lists.length; i++) {const result = await this.uploadFilePromise(lists[i].url)console.log(result);if(result.success){let item = this.fileList[fileListLen]this.fileList.splice(fileListLen, 1, Object.assign(item, {status: 'success',message: '',url: result}))fileListLen++}else{this.fileList.splice(fileListLen, 1)}}},//上传图片uploadFilePromise(url) {return new Promise((resolve, reject) => {let a = uni.uploadFile({url:'http://192.168.2.21:7001/upload', // 仅为示例,非真实的接口地址,换成自己上传图片的接口filePath: url,name: 'file',success: (uploadRes) => {setTimeout(()=>{let res = JSON.parse(uploadRes.data) //最终传给的是字符串,这里需要转换格式if(res.code == 0){this.$common.msg(res.msg)resolve({success:false,url:''})return;}resolve({success:true,url:res.data.url})},2000)}});})},//点击确认还需要些许修改fabu() {let images = []this.fileList.forEach((item) => {images.push(item.url.url)})// 其他接口request('post', '其他接口地址', {title: this.textValue,info: this.textValue,images: images.join(',')//重点是这里,需要看后台接收的类型进行更改}).then(res => {if (res.code == 1) {console.log(res);}})},}图片上传// 图片上传//删除图片deletePic(event) {this[`fileList${event.name}`].splice(event.index, 1)},// 新增图片async afterRead(event) {// 当设置 multiple 为 true 时, file 为数组格式,否则为对象格式let lists = [].concat(event.file)let fileListLen = this[`fileList${event.name}`].lengthlists.map((item) => {this[`fileList${event.name}`].push({...item,status: 'uploading',message: '上传中'})})for (let i = 0; i < lists.length; i++) {const result = await this.uploadFilePromise(lists[i].url)console.log("结果", result);if (result.success) {let item = this.fileList[fileListLen]this.fileList.splice(fileListLen, 1, Object.assign(item, {status: 'success',message: '',url: result}))fileListLen++} else {this.fileList.splice(fileListLen, 1)}}},uploadFilePromise(url) {return new Promise((resolve, reject) => {let a = uni.uploadFile({url: config[config.env].apiUrl + '/api/common/upload', // 仅为示例,非真实的接口地址filePath: url,name: 'file',formData: {user: 'test'},success: (uploadRes) => {setTimeout(() => {let res = JSON.parse(uploadRes.data) //最终传给的是字符串,这里需要转换格式if (res.code == 0) {this.$common.msg(res.msg)resolve({success: false,url: ''})return;}console.log("图片", res);resolve({success: true,url: res.data.url})}, 1000)}});})},单图传值data(){return{payment_credentials:''//支付凭证(线下必填)}},methods: {aaa(){if (this.fileList.length > 0) {this.payment_credentials = this.fileList[0].url.url}}}图片回显

当内容进行修改时,需要先将上次上传过的图片进行显示(后台会返回图片数组),之后或许删除上次中的某种图片,也有可能会新上传一些图片。最后提交给后台的数据的图片数组是不带域名的。 整体步骤如下:

data() {return {// 图片列表fileList: [],//修改功能 需要提交的图片数组subImg:[]}},1.修改,根据id 进行查询此条数据的信息,后台返回该条数据信息,这里只说图片的事。首先对images进行处理,字符串转化为数组,之后对分割后的数组subImg进行遍历循环,把图片路径(拼接好域名之后)push到fileList数组里面,这时候页面的图片就能显示了。this.subImg = res.data.images.split(',') //字符串转化为数组this.subImg.forEach(item=>{console.log(item);this.fileList.push({url: this.$common.image(item)//拼接好域名之后push进去})})console.log(this.fileList);

2.由于修改之后提交给后台的图片数组是不带域名的,所以自定义了一个subImg数组,刚上来的时候就已经赋进去了最初始的两张图,如果删除,就根据删除的下标删除掉此数组里面的图片,每次上传新图片的时候,就把新上传后返回的图片路径push进去,这样 不管是删除还是新增都能保证sunImg数组里面的图片都是最新的,且不带域名

核心代码:

this.subImg.splice(e.index, 1)this.subImg.push(res.data.url)

具体代码:

//删除图片deletePic(e) {console.log(e);this.fileList.splice(e.index, 1)this.subImg.splice(e.index, 1) //新增删除代码},// 新增图片async afterRead(event) {// 当设置 mutiple 为 true 时, file 为数组格式,否则为对象格式let lists = [].concat(event.file)let fileListLen = this.fileList.lengthlists.map((item) => {this.fileList.push({...item,status: 'uploading',message: '上传中'})})for (let i = 0; i < lists.length; i++) {const result = await this.uploadFilePromise(lists[i].url)console.log(result);if (result.success) {let item = this.fileList[fileListLen]this.fileList.splice(fileListLen, 1, Object.assign(item, {status: 'success',message: '',url: result}))fileListLen++} else {this.fileList.splice(fileListLen, 1)}}},//上传图片uploadFilePromise(url) {return new Promise((resolve, reject) => {let a = uni.uploadFile({url: config[config.env].apiUrl + '/api/common/upload',filePath: url,name: 'file',success: (uploadRes) => {setTimeout(() => {let res = JSON.parse(uploadRes.data) //最终传给的是字符串,这里需要转换格式if (res.code == 0) {this.$common.msg(res.msg)resolve({success: false,url: ''})return;}console.log("图片", res.data.url);this.subImg.push(res.data.url) //新增添加代码resolve({success: true,url: res.data.url})}, 2000)}});})},
本文链接地址:https://www.jiuchutong.com/zhishi/283634.html 转载请保留说明!

上一篇:ValueError: all the input arrays must have same number of dimensions, but the array at index 0 has 1

下一篇:绿萝怎么养(图文)(绿萝怎么样养)

  • 华为耳机怎么连接ipad(华为耳机怎么连接苹果ipad)

    华为耳机怎么连接ipad(华为耳机怎么连接苹果ipad)

  • 苹果13pro怎么关闭app资源库(苹果13pro怎么关闭5g)

    苹果13pro怎么关闭app资源库(苹果13pro怎么关闭5g)

  • 有候补订单还能抢票吗(有候补订单还能买第二天的票吗)

    有候补订单还能抢票吗(有候补订单还能买第二天的票吗)

  • nova 5pro耳机孔在哪里(nova5ipro耳机插口)

    nova 5pro耳机孔在哪里(nova5ipro耳机插口)

  • 如何下载快手上的视频(如何下载快手上已付费的视频)

    如何下载快手上的视频(如何下载快手上已付费的视频)

  • 拼多多导入订单不发货的原因(拼多多订单导出怎么操作)

    拼多多导入订单不发货的原因(拼多多订单导出怎么操作)

  • 计算机用来表示存储空间大小的基本单位(计算机用来表示内存储器容量的基本单位是)

    计算机用来表示存储空间大小的基本单位(计算机用来表示内存储器容量的基本单位是)

  • 860k能带什么显卡(860k带核显吗)

    860k能带什么显卡(860k带核显吗)

  • 手机上照片怎么重命名(手机上照片怎么上传到报名表上)

    手机上照片怎么重命名(手机上照片怎么上传到报名表上)

  • 爱奇艺快进设置方法(爱奇艺快进设置秒数)

    爱奇艺快进设置方法(爱奇艺快进设置秒数)

  • 腾讯视频王卡怎么免流(腾讯视频王卡怎么退订订单)

    腾讯视频王卡怎么免流(腾讯视频王卡怎么退订订单)

  • 苹果11测距仪怎么用(苹果测距仪怎么测身高)

    苹果11测距仪怎么用(苹果测距仪怎么测身高)

  • coolpad手机为什么开不了机(coolpad手机为什么连不上wifi)

    coolpad手机为什么开不了机(coolpad手机为什么连不上wifi)

  • 苹果闹钟开着会一直响吗(苹果闹钟开着会耗电吗)

    苹果闹钟开着会一直响吗(苹果闹钟开着会耗电吗)

  • iphone7内存有哪些(iphone 7的内存)

    iphone7内存有哪些(iphone 7的内存)

  • 网易云怎么取消收藏(网易云怎么取消和别人一起听)

    网易云怎么取消收藏(网易云怎么取消和别人一起听)

  • 8p是多少寸屏幕(iphone 8p是多少寸)

    8p是多少寸屏幕(iphone 8p是多少寸)

  • ps去色在哪(ps里面去色怎么用)

    ps去色在哪(ps里面去色怎么用)

  • 苹果se128g上市时间(苹果se128g售价多少钱)

    苹果se128g上市时间(苹果se128g售价多少钱)

  • 华为blnal20是什么型号(华为bla_l29是什么手机)

    华为blnal20是什么型号(华为bla_l29是什么手机)

  • 手机wps怎么新建文件夹(手机Wps怎么新建文档)

    手机wps怎么新建文件夹(手机Wps怎么新建文档)

  • 红魔是什么牌子的手机(红魔是什么牌子的手机多)

    红魔是什么牌子的手机(红魔是什么牌子的手机多)

  • html怎么引入JavaScript代码(html怎么引入图片)

    html怎么引入JavaScript代码(html怎么引入图片)

  • iframe嵌套页面传值(iframe嵌套页面点击里面的按钮)

    iframe嵌套页面传值(iframe嵌套页面点击里面的按钮)

  • 收到财政局拨款填到现金流量表哪一项
  • 折扣折让红字发票怎么做账务处理
  • 联合体项目工程款如何拨付
  • 资产总额季度平均值计算公式
  • 小规模增值税减免会计账务处理
  • 预付加油卡发票可以报销吗
  • 滴滴的发票能不能作废
  • 合同签订之后国家降税怎么办?
  • 坏账准备递延所得税资产怎么算
  • 固定资产被盗报警
  • 建设工程项目融资
  • 离职员工的工资应该多久结清
  • 增值税普通发票几个点
  • 过路费去年的票还可以用吗
  • 不涉及税收
  • 异地预缴增值税后本地还要交吗
  • 专用发票百万元版申请要求
  • 单位不发工资怎么解决要什么证据
  • 公司商品质量问题导致员工与公司一起被起诉了怎么办
  • 非同一控制企业合并商誉
  • 季度申报的小规模纳税人怎么查看销售额达到500万
  • 无形资产管理费用不计入
  • 什么叫抵免
  • 固定资产转入清理记账凭证
  • win101703怎么看
  • 打方向咯噔一声已解决
  • 华为p20上市时间和价格
  • 机票行程单可以报销用吗
  • 建筑业产值填哪个数据
  • 年终奖计提和发放
  • 怎么修改?
  • 羽毛球脚踝扭伤怎么办
  • 销售免税农产品进项税可以抵扣吗
  • 出口商品要交增值税吗
  • 在建工程账务处理管理制度
  • 兰溪园林绿化养护
  • php读取文件
  • react router教程
  • css calculate
  • rmt命令 远端磁带传输协议模块
  • 修改命令的快捷键
  • php执行命令的函数
  • excel&命令
  • 成品油发票如何下载库存
  • 进项税加计抵减是什么意思
  • 企业应收账款的规模受哪些因素的影响?( )
  • 教大家8天学通MongoDB——第一天 基础入门篇
  • 企业怎么开启承兑业务
  • 什么是指企业的市场营销活动发生影响的各种因素的总和
  • 车辆购置税可以网上缴纳吗
  • 新收入准则确认收入的条件
  • 现金余额出现负数的原因
  • 有差价的商品发票怎么开
  • 政府补助冲减成本
  • 无形资产减值准备
  • 销户还能申请抚养费吗?
  • 年度的汇算清缴
  • 内连接 sql
  • sql命令语句
  • Win10 Build 10565 Edge浏览器更新日志和已知问题
  • ftp的安装
  • 如何关闭windows防火墙
  • 双系统没有选择
  • win7系统如何查找文件
  • win7系统怎么连接wifi
  • 清除win7更新缓存
  • linux中docker
  • win7系统回收站文件夹的位置
  • Unity3D游戏开发毕业论文
  • 老生常谈的错别字
  • shell脚本mysql
  • jquery的dialog怎么使用
  • node.js模块
  • python中deque
  • unity3d怎么用
  • python做脚本语言怎么用
  • 发票换领
  • 建筑行业增值税11%
  • 土地使用税一般谁交
  • 怎么查国税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设