vue3中怎么点击按钮就上传文件

html 复制代码
<el-button text type="primary" @click="importBillExcel(row)">导入账单</el-button>
javascript 复制代码
// 导入客户账单Excel表
const importBillExcel = (row) => {
    let input = document.createElement('input')
    input.type = 'file'
    input.accept = '.pdf, .png, .zip, .jpg'; // 限制选择的文件类型为 .pdf, .png, .zip, .jpg
    input.style.display = 'none'
    document.body.appendChild(input)
    input.click();
    input.onchange = (e) => {
        const file = e.target.files[0] // 获取文件对象
        let paramsFile = new FormData() // 转为表单格式
        paramsFile.append('file',file) // 添加属性和值
        paramsFile.append('receivableBillSn',row.receivableBillSn) // 添加属性和值
        importCustomerBill(paramsFile).then(res=>{
            document.body.removeChild(input)
        })
    }
}

说明:file和receivableBillSn是接口importCustomerBill需要传递的参数;整个实现过程就是利用了input标签的type="file"的属性,这个属性就是可以弹出文件选择对话框;importBillExcel方法中就是创建了一个input节点添加type="file"属性,最后在移除input节点;

效果

相关推荐
前端程序猿i12 分钟前
用本地代理 + ZIP 打包 + Excel 命名,优雅批量下载跨域 PDF
前端·javascript·vue.js·html
Danny_FD21 分钟前
Vue2 中使用vue-markdown实现编辑器
前端·javascript·vue.js
用户游民21 分钟前
Flutter 项目热更新加载 libapp.so 文件
前端
coding随想22 分钟前
Vue和React对DOM事件流的处理方法解析
前端
用户479492835691523 分钟前
字节面试官:forEach 为什么不能被中断?
前端·javascript
ccnocare23 分钟前
window.electronAPI.send、on 和 once
前端·electron
tager28 分钟前
🍪 让你从此告别“Cookie去哪儿了?”
前端·javascript·后端
阿吉被迫了解低代码34 分钟前
前端:“学算法?狗都不... !”
前端
前端赵哈哈39 分钟前
Vue 3 + TypeScript 项目模板
前端·vue.js·vite
南囝coding42 分钟前
命令行神器 The Fuck,敲错命令的后悔药
前端·后端