当前位置:   article > 正文

微信小程序实现图片上传_微信小程序图片上传

微信小程序图片上传

微信小程序实现图片上传

最近做了个小程序,涉及到了图片上传的功能,今天给大家详细介绍下如何实现小程序图片上传,话不多说先上代码

首先是静态布局和样式部分

.wxml代码部分

  1. <view class='load-img'>
  2. <view class='load-box'>
  3. <view class='img-item' wx:for="{{fileList}}" wx:key="index" >
  4. <image src="{{item.path}}" data-src="{{item}}" mode="aspectFill" data-list="{{fileList}}" bindtap=""></image>
  5. <icon class='icon' type="clear" size="20" color='#EF4444' catchtap='_onDelTab' data-idx="{{index}}" wx:if="{{!prevent}}"/>
  6. </view>
  7. <image class='img-add' bindtap='_addImg' wx:if="{{!prevent}}"></image>
  8. </view>
  9. </view>

.wxss代码部分

  1. /* 上传图片 */
  2. .load-name {
  3. height: 80rpx;
  4. line-height: 80rpx;
  5. font-size: 30rpx;
  6. }
  7. .load-box {
  8. display: flex;
  9. flex-direction: row;
  10. flex-wrap: wrap;
  11. }
  12. .img-item, .img-add {
  13. position: relative;
  14. width: 140rpx;
  15. height: 140rpx;
  16. margin: 20rpx;
  17. }
  18. .img-add {
  19. border: 1px solid #ccc;
  20. }
  21. .img-add:after{
  22. width: 1rpx;
  23. height: 50rpx;
  24. content: " ";
  25. position: absolute;
  26. top: 50%;
  27. left: 50%;
  28. -webkit-transform: translate(-50%, -50%);
  29. -ms-transform: translate(-50%, -50%);
  30. transform: translate(-50%, -50%);
  31. background-color: #ccc;
  32. }
  33. .img-add:before{
  34. position: absolute;
  35. top: 50%;
  36. right: 31%;
  37. width: 50rpx;
  38. height: 1rpx;
  39. content: " ";
  40. display: inline-block;
  41. background-color: #ccc;
  42. }
  43. .img-item {
  44. margin-right: 20rpx;
  45. }
  46. .img-item image {
  47. width: 100%;
  48. height: 100%;
  49. border-radius: 10rpx;
  50. }
  51. .icon {
  52. position: absolute;
  53. top: 0;
  54. right: 0;
  55. }

以上这些基本代码就可以完成图片上传,显示,删除等样式布局

下面是js的部分,我已详细备注~~~

先来看下完整的代码

  1. /**
  2. * 小程序图片上传
  3. * 组件接受参数
  4. * fileList 图片数组
  5. * prevent 控制是否可新增
  6. * 方法
  7. * bindimageChange 选择图片后触发
  8. * bindimageDel 删除图片后触发
  9. *
  10. */
  11. const app = getApp();
  12. Component({
  13. properties: {
  14. fileList: {
  15. type: Array
  16. },
  17. prevent: {
  18. type: Boolean,
  19. value: false
  20. }
  21. },
  22. data: {
  23. fileList: []
  24. },
  25. ready() {},
  26. methods: {
  27. // 点击加号进入手机相册,并进行图片选择
  28. _addImg() {
  29. let _this = this;
  30. // 此方法为微信小程序自带api 详情访问https://developers.weixin.qq.com/miniprogram/dev/api/media/image/wx.chooseImage.html
  31. wx.chooseImage({
  32. count: 5,
  33. success(res) {
  34. //此处会返回图片暂存路径和文件大小
  35. const data = res.tempFiles;
  36. _this.setFile(data)
  37. }
  38. })
  39. },
  40. setFile (data) {
  41. // 将wx.chooseImage返回的数据进行扩展
  42. data.map((item, index) => {
  43. // 通过路径截取文件后缀名
  44. const fileFormat = item.path.substring(item.path.lastIndexOf(".") + 1, item.path.length);
  45. // wx.getFileSystemManager()小程序文件管理器api,可以将通过文件路径将其转换成64编码
  46. const fileManager = wx.getFileSystemManager();
  47. const base64 = fileManager.readFileSync(item.path, 'base64');
  48. item.fileContent = base64;
  49. item.fileSize = item.size;
  50. // 通过时间获取随机13位随机数并且拼接文件后缀进行文件命名
  51. item.fileName = this.getFileName(13) + '.' + fileFormat;
  52. // 此处操作是用来进行选中图片显示的,只有这样拼接才能显示base64编码的路径
  53. item.path = `data:image/${fileFormat};base64,${base64}`;;
  54. })
  55. this.setData({
  56. fileList: this.data.fileList.concat(data)
  57. });
  58. // 此处操作是用来将获取到的文件数据传递给父组件进行文件上传
  59. this.triggerEvent('imageChange', this.data.fileList)
  60. },
  61. // 随机生成文件名
  62. getFileName (m) {
  63. m = m > 13 ? 13 : m;
  64. var num = new Date().getTime();
  65. return num.toString().substring(13 - m);
  66. },
  67. 点击进行图片删除
  68. _onDelTab(e) {
  69. // 获取图片索引
  70. let idx = e.currentTarget.dataset.idx;
  71. let delFile = this.data.fileList[idx];
  72. console.log(delFile);
  73. this.data.fileList.splice(idx, 1);
  74. this.setData({
  75. fileList: this.data.fileList
  76. })
  77. this.triggerEvent('imageDel', delFile);
  78. }
  79. })

代码里对代码的备注已经很明确了,大家仔细扒一下,根据的自己的项目进行相应的调整,基本上都是没问题的,~~不要直接直接粘贴不复置,我是直接在我的项目中直接拿过来的代码,直接粘贴复制肯定是不行的!!!~~

大家需要注意的是这里

通常在真机上点击选中图片后wx.chooseImage方法中返回的文件路径是wxfile:开头的路径,这样的路径想直接转成base64,上面的方式是可以实现的,我也是查了很多资料才找到的解决办法。

再一个需要注意的是image src属性想显示base64格式的图片要进行字符串拼接才可以正常显示如下图

好啦这些就是我小程序上传图片的操作,这些只是我对日常工作的积累,不喜勿喷 不喜勿喷 不喜勿喷 重要的事情说三遍,大家仔细看下代码理解用法,还是很简单的,看都不看想白漂肯定是不行的呦~~~~~~~~~
 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/556499
推荐阅读
相关标签
  

闽ICP备14008679号