方法一:
页面展示:
Html部分代码:
<el-upload
accept=".pdf"
name="fileName"
class="upload-demo"
multiple
action="https://xxxxxxxxxxxx"
:headers="headers"
:file-list="fileList"
:auto-upload="false"
:on-preview="handlePreview"
:on-remove="handleRemove"
:on-change="handleChange"
>
<el-button size="default" icon="el-icon-upload" type="primary" round>上传文件</el-button>
</el-upload>
<span slot="footer" class="dialog-footer">
<el-button size="default" @click="uploadDialog = false">取 消</el-button>
<el-button type="primary" size="default" :disabled="!fileList.length" @click="submitUpload">确定</el-button>
</span>
accept | 用于限制允许上传哪些类型文件 |
name | 上传的文件字段名 (默认为 file) |
multiple | 是否支持多选文件 |
action | 必选参数,上传的地址 |
headers | 设置上传的请求头部 |
file-list | 上传列表 |
auto-upload | 是否在选取文件后立即进行上传 |
主要逻辑:
1. 多选文件,multiple必填
2. 若需要修改 上传的文件字段名,则设置name
3. 关闭自动上传,设置auto-upload
4. 将所有选择的文件,保存到 file-list 绑定的数组属性中
5. 利用FormData对象,将文件传给后端
Javascript部分代码:
submitUpload() {
const formData = new FormData();
// 额外参数,根据自身情况添加
formData.append('contract_id', this.uploadParams.contract_id);
/**
* 所有选择的文件,放到FormData对象中上传
* fileName[] 属性名根据自身情况定义
*/
this.fileList.map((file) => {
formData.append('fileName[]', file.raw)
});
uploadContract(formData).then(response => {
this.msgSuccess(response.message);
this.uploadDialog = false;
this.getContractList();
this.fileList = [];
});
},