js实现自定义唤起文件选择窗口获取文件

代码:
 

/**
 * 唤起文件选择窗口,并获取选择的文件
 * @param {*} multiple // 是否支持多选
 * @param {*} accept // 文件上传格式限制
 * @param {*} limit // 单次上传最大数
 * @param {*} fileSize // 单次上传最大数
 * @returns
 */
export async function getWinFiles (options) {
    const { multiple, accept, limit, fileSize, dropzone } = {
        multiple: true,
        accept: '',
        limit: 1,
        fileSize: 500,
        ...options,
    }

    // 创建文件选择元素
    const input = document.createElement('input')
    input.setAttribute('type', 'file')
    input.setAttribute('style', 'display:none')
    input.setAttribute('multiple', multiple)
    input.setAttribute('accept', accept)
    input.setAttribute('dropzone', dropzone)
    // 将文件选择元素添加到文档中
    document.body.appendChild(input)

    // 触发文件选择元素的点击事件
    input.click()

    // 等待文件选择元素的change事件
    const files = await new Promise((resolve, reject) => {
        input.addEventListener('change', e => {
            const files = Object.values(e.target.files) || []

            // 从文档中移除文件选择元素
            document.body.removeChild(input)

            // 判断是否超出上传数量限制
            if (files.length > limit) {
                reject({ errorType: 'limit', files })
                return
            }

            // 判断是否超出上传文件大小限制
            if (files.some(i => i.size / 1024 ** 2 > fileSize)) {
                reject({ errorType: 'fileSize', files })
                return
            }
            // 抛出附件,并生成附件uid
            resolve(files.map((file, index) => ({ file, uid: Date.now() + index })))
        })
    })

    return files
}

使用方法:
 

/* 点击获取文件 */
async function getFiles(accept, fileSize) {
        const files = await getWinFiles({ limit, accept, fileSize }).catch(error => {console.log(error,'获取错误截获!')})
    console.log(files,'获取到文件了!')
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值