<template>
<div id="app">
<!--
action:存放的是文件上传到服务器的接口地址
-->
<!--组件里 show-file-list 是否显示已上传文件列表 -->
<!--组件里 on-success 文件上传成功时的钩子,成功时触发 -->
<!-- before-upload 上传文件之前的钩子,参数为上传的文件,若返回 false 或者返回 Promise 且被 reject,则停止上传。 -->
<!-- action存放的是上传到服务器的接口地址 -->
<el-upload
drag
action="/single1"
:show-file-list="false"
:on-success="handleSuccess"
:before-upload="beforeUpload"
>
<i class="el-icon-upload"></i>
<div class="el-upload__text">
将文件拖到此处,或
<em>点击上传</em>
</div>
</el-upload>
<!-- IMG -->
<div class="uploadImg" v-if="img">
<img :src="img" alt />
</div>
</div>
</template>
<script>
/*
* 文件上传有两套方案:
* 1. 基于文件流(form-data) element-ui上传组件默认是基于文件流的
* 2. 客户端需要把文件转化为BASE64
*
* 默认上传
* 格式:multipart/form-data
* 数据格式:form-data
* file 文件流信息
* filename 文件名字
* 上传成功后获取服务器返回信息,通知on-success回调函数执行
* 内部封装了ajax
*/
export default {
name: "App",
data() {
return {
img: null,
};
},
methods: {
// <!--组件里 on-success 文件上传成功时的钩子,成功时触发 result是服务器返回的结果-->
handleSuccess(result) {
//通过服务器返回的code值,判断成功 然后将返回的path地址,赋值给img
if (result.code == 0) {
this.img = result.path;
}
},
// 组件里before-upload上传文件之前的钩子,参数为上传的文件,若返回 false 或者返回 Promise 且被 reject,则停止上传
// 在这里面判断一些条件,例如多大的,什么格式的才能上传
beforeUpload(file) {
// 格式校验----------------------------
console.log(file) //可以知道得到文件的type类型和文件的size大小
let { type, size } = file; //file这个属性因为包含这两个值,分别赋值给变量
//判断文件的格式 正则表达式 匹配文件类型
if (!/(png|gif|jpeg|jpg)/i.test(type)) {
this.$message("文件合适不正确~~"); //组件的提示方法
return false; //既然判断出格式不正确,那么就return 终止函数,不往下走了
}
//判断文件大小1024B=1KB 1024KB=1MB 假设限定必须在200M以内的
if (size > 200 * 1024 * 1024) {
this.$message("文件过大,请上传小于200MB的文件~~");
return false;
}
return true; // beforeUpload(file) 最终是返回ture的
},
},
};
</script>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决