uniapp上传图片和上传视频方法封装

uniapp上传图片和上传视频方法封装
新建一个utils.js文件,存放封装的方法
在这里插入图片描述
utils.js文件里面的方法如下:


import Config from '@/common/baseConfig.js';  //这个文件里面配置有上传文件地址
export default {
  
  /**
   * 图片选择加上传
   * @param number num
   * @param {Object} params
   * @param {Object} callback
   * @param string url
   * return array
   */
  upload: function(num, callback, url) {
  
  	var imgs_num = num;
  	var _self = this;
  	uni.chooseImage({
  		count: imgs_num,
  		sizeType: ['compressed'], //可以指定是原图还是压缩图,默认二者都有
  		sourceType: ['album', 'camera'], //从相册或者拍照
  		success: async function(res) {
  			const tempFilePaths = res.tempFilePaths;
  			var imgs = [];
  			for (var i = 0; i < tempFilePaths.length; i++) {
  				var path = await _self.upload_file_server(tempFilePaths[i], '', url);
  				imgs.push(path);
  			}
  			typeof callback == 'function' && callback(imgs);
  		}
  	});
  },
  /**
   * 视频选择加上传
   * @param number num
   * @param {Object} params
   * @param {Object} callback
   * @param string url
   * return array
   */
  uploadVideo: function(callback, url) {
  	var _self = this;
  	uni.chooseVideo({
  		sizeType: ['compressed'], //可以指定是原图还是压缩图,默认二者都有
  		sourceType: ['album', 'camera'], //从相册或者拍照
  		success: async function(res) {
        console.log(res)
  			const tempFilePaths = res.tempFilePath;
        
  			var path = await _self.upload_file_server(tempFilePaths, '', url);
  				
  			typeof callback == 'function' && callback(path);
  		}
  	});
  },
  //上传
  upload_file_server(tempFilePath, path, url = "") {
  	if (url) {
  		var uploadUrl = Config.upload
  	} else {
  		var uploadUrl = Config.upload
  	}
    console.log(tempFilePath)
    console.log(uploadUrl)
  	return new Promise((resolve, reject) => {
  		uni.uploadFile({
  			url: uploadUrl,
  			filePath: tempFilePath,
  			name: 'file',
  			success: function(res) {
  				var path_str = JSON.parse(res.data);
  				if (path_str.code >= 0) {
  					resolve(path_str.url);
  				} else {
  					reject("error");
  				}
  			}
  		});
  
  	});
  },
}

在项目根目录下的main.js文件里面引入并声明该文件:

import Utils from './utils/utils.js'
Vue.prototype.$utils = Utils;

在fabu.vue页面里面使用:

//上传图片
      uploadImg() {
       this.$utils.upload(9,res => {
         if(res.length>0) {
           res.forEach((v) => {
              this.img.push(v)
           })
         }
       })
      },
      //上传视频,默认一个
      uploadVideo() {
        this.$utils.uploadVideo(res => {
          if(res) {
            this.video = res;
          }
        })
      },
      //删除图片
      delImg(index) {
        this.img.splice(index,1)
      },
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值