xe-upload上传文件插件

1.xe-upload地址:文件选择、文件上传组件(图片,视频,文件等) - DCloud 插件市场

2.由于开发app要用到上传文件组件,uni.chooseFile在app上不兼容,所以找到了xe-upload,兼容性很强,强烈推荐!!!

说明

不占用页面位置的上传组件;

H5、App、微信小程序中可上传图片,视频和文件;其他端暂时只能上传图片和视频

上传图片通过chooseMediachooseImage实现

上传视频通过chooseMediachooseVideo实现

H5端上传文件通过chooseFile实现

App上传文件通过renderjs实现

微信小程序上传文件通过chooseMessageFile实现

3.使用方法,到插件市场将插件包导入到自己的项目,然后下列方式调用。

复制代码
<!-- 也可以下载示例项目查看使用方法 -->
<template>
    <view>
        <button @click="handleUploadClick">上传</button>
        <xe-upload ref="XeUpload" :options="uploadOptions" @callback="handleUploadCallback"></xe-upload>
    </view>
</template>

<script>
export default {
    data() {
        return {
            uploadOptions: {
                // url: 'http://192.168.31.185:3000/api/upload', // 不传入上传地址则返回本地链接
            },
        };
    },
    methods: {
        handleUploadClick() {
            // 使用默认配置则不需要传入第二个参数
            // type: ['image', 'video', 'file'];
            this.$refs.XeUpload.upload('file', {});
            // this.$refs.XeUpload.upload('image', {
            //  count: 6,
            //  sizeType: ['original', 'compressed'],
            //  sourceType: ['album'],
            // });
        },
        handleUploadCallback(e) {
            // e.type: ['choose', 'success', 'warning']
            // choose 是options没有传入url,返回临时链接时触发
            // success 是上传成功返回对应的数据时触发
            // warning 上传或者选择文件失败触发
            // ......
        },
    },
};
</script>

4.回调绑定callback方法:

回调返回的参数:

复制代码
'callback.type === success' : [
    {
        "size": 176579, // 选择的文件的大小
        "name": "Kafka.pdf", // 选择的文件的名称(小程序端可能会没有)
        "type": "application/pdf",
        "tempFilePath": "_doc/uniapp_temp/Kafka-16988473328760.pdf", // 临时路径
        "fileType": "file", // 文件类型[image, video, file]
        "response": {
            "result": {
                "fileName": "Kafka.pdf",
                "filePath": `http://localhost:3000/upload/e51d814b649122fc64892d0bc6383d07.pdf`,
            },
            "success": true,
        }, // 上传返回的信息
    }
]

'callback.type === choose' : [
    {
        "size": 176579, // 选择的文件的大小
        "name": "Kafka.pdf", // 选择的文件的名称(小程序端可能会没有)
        "type": "application/pdf",
        "tempFilePath": "_doc/uniapp_temp/Kafka-16988473328760.pdf", // 文件临时路径
        "fileType": "file", // 文件类型[image, video, file]
    }
]

5.注意事项

1、options入参中如果url为空,则choose回调的data列表中只有选择文件能得到的信息和临时路径,临时路径可用于自定义上传方法;传入url选择文件后会自动上传到服务器,此时choose回调不会触发,而是执行success回调,success回调的data列表会包括选择文件能得到的信息
2、当uni.chooseMedia可用时,会优先使用uni.chooseMedia
3、具体使用可下载示例项目运行查看完整示例
相关推荐
Hyyy7 小时前
普通前端续命周报——第1周
前端·javascript
KaMeidebaby8 小时前
卡梅德生物技术快报|抗独特型抗体开发:半抗原检测技术瓶颈拆解,抗独特型抗体开发工程化实践
前端·数据库·人工智能·其他·百度·新浪微博
2501_940041748 小时前
纯前端创意交互:五款全新实用工具与视觉应用生成指南
前端·交互
刀法如飞8 小时前
《道德经》简单解说版-第 2 章:天下皆知美之为美
前端·后端·面试
发现一只大呆瓜10 小时前
超全 Vite 性能优化指南:网络、资源、预渲染三维落地方案
前端·面试·vite
IT_陈寒10 小时前
Vue的computed属性怎么突然不更新了?
前端·人工智能·后端
智商不够_熬夜来凑11 小时前
【Picker】单选多选
前端·javascript·vue.js
米饭不加菜11 小时前
Typora 原生流程图语法完全指南(Flowchart.js)
前端·javascript·流程图
scan72411 小时前
langgraphy条件边
前端·javascript·html
冰小忆12 小时前
类变量在继承场景下的初始化规则是怎样的?
java·前端·数据库