文章目录
- element上传附件(el-upload 超详细)
- 代码展示
- html代码
- data中
- methods中
- 接口写法
- 总结
element上传附件(el-upload 超详细)
这个功能其实比较常见的功能,后台管理系统基本上都有,这就离不开element的el-upload
展示:
代码展示
html代码
<el-upload class="upload-demo" :on-preview="handlePreview" :on-remove="handleRemove" action=""
:before-remove="beforeRemove" multiple :limit="1" :on-exceed="handleExceed" :file-list="fileList"
:http-request="httpRequest">
<el-button size="small" type="primary">点击上传</el-button>
<div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div>
</el-upload>
data中
fileList: [{ name: 'food.jpeg', url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100' }]
methods中
//实现图片上传功能
httpRequest(item) {
// var imgId = item.file.lastModified
console.log(item.file.name);
this.fileList[0].name = item.file.name
var formData = new FormData()
formData.append('file', item.file)
// {
// // 设置请求头为 multipart/form-data
// headers: {
// 'Content-Type': 'multipart/form-data'
// },
// // // 上传进度
// // onUploadProgress: progressEvent => {
// // let percent = ((progressEvent.loaded / progressEvent.total) * 100) | 0
// // //调用onProgress方法来显示进度条,需要传递个对象 percent为进度值
// // item.onProgress({ percent: percent })
// // }
// }
upload(formData)
.then(res => {
this.fileList[0].name = item.file.name
console.log(res);
})
.catch(() => { })
},
handleRemove(file, fileList) {
console.log(file, fileList);
},
handlePreview(file) {
console.log(file);
},
handleExceed(files, fileList) {
this.$message.warning(`当前限制选择 1 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个文件`);
},
beforeRemove(file, fileList) {
return this.$confirm(`确定移除 ${file.name}?`);
},
接口写法
// 上传图片
export function upload(data) {
return request({
url: '/upload',
method: 'post',
data,
headers: {
'Content-Type': 'multipart/form-data'
},
})
}
总结
这个功能确实是非常常见的,尤其在后台管理系统中,文件上传功能几乎是标配。而Element UI,作为一个基于 Vue 的高质量 UI 组件库,其 el-upload 组件提供了非常便捷的文件上传功能。
el-upload 组件允许开发者轻松地实现文件选择、上传、预览以及错误处理等功能。通过简单的配置和事件监听,开发者可以定制上传按钮的样式、上传进度显示、上传成功或失败后的回调函数等。此外,el-upload 还支持多种上传方式,如拖拽上传、多文件上传等,极大地丰富了用户的使用体验。
在后台管理系统中,文件上传功能通常与表单管理、用户管理等模块紧密结合。例如,管理员可能需要上传用户头像、更新系统配置文件、导入导出数据等。在这些场景中,el-upload 组件都能够发挥出其强大的作用。
除了基本的文件上传功能外,开发者还可以结合后端接口,实现更加复杂的文件处理逻辑,如文件校验、断点续传、文件加密等。这些高级功能可以进一步提升文件上传的效率和安全性,满足各种复杂的业务需求。
el-upload 组件作为 Element UI 中的一个重要组件,为开发者提供了便捷、高效的文件上传解决方案。无论是在后台管理系统中,还是在其他需要文件上传功能的场景中,它都能够发挥出其独特的优势,帮助开发者快速构建出稳定、可靠的文件上传功能。
您好,我是肥晨。
欢迎关注我获取前端学习资源,日常分享技术变革,生存法则;行业内幕,洞察先机。