前一段时间做项目,频繁使用到上传图片组件,而且只上传一个封面,于是想着自定义一个图片封面上传组件。先来看一下效果:

                      
第一张图片是上传之前,第二张图片是上传成功后,第3张图片是鼠标放上去之后的效果!
 
首先整理需求,图片上传我们使用照片墙的方式,只能上传一张图片,图片上传成功后不能继续上传,如果想要更换图片,则需要将图片删除后重新上传。点击图片上面的放大镜可以查看大图。
需要限制图片上传的格式,图片的大小。
 
组件代码:
  1 <template>
2 <div class="upload">
3 <el-upload
4 :class="{'hidden':mFileList.length > 0}"
5 list-type="picture-card"
6 :on-remove="handleRemove"
7 :action="action"
8 :before-upload="beforeUploadHandle"
9 :on-success="successHandle"
10 :on-change="changeHandle"
11 :limit="1"
12 :accept="accept"
13 :on-exceed="handleExceed"
14 :file-list="fileList"
15 :on-preview="handlePictureCardPreview"
16 >
17 <i class="el-icon-plus"></i>
18 </el-upload>
19 <el-dialog :visible.sync="dialogVisible">
20 <img width="100%" :src="dialogImageUrl" alt="" />
21 </el-dialog>
22 </div>
23 </template>
24
25 <script>
26 export default {
27 props: {
28 action: {
29 type: String,
30 default: "",
31 },
32 accept: {
33 type: String,
34 default: "",
35 },
36 fileList:{
37 type: Array,
38 default: () => [],
39 },
40 },
41 watch: {
42 fileList(newValue, oldValue) {
43 this.mFileList = newValue
44 }
45 },
46 data() {
47 return {
48 dialogVisible: false, //图片放大
49 fileImg: "", //上传图片
50 dialogImageUrl: "", //图片地址
51 mFileList:this.fileList,
52 };
53 },
54 methods: {
55 handleRemove(file, fileList) {
56 this.$emit("upload-remove", file);
57 },
58 handlePictureCardPreview(file) {
59 this.dialogImageUrl = file.url;
60 this.dialogVisible = true;
61 },
62 // 上传之前
63 beforeUploadHandle(file) {
64 if (file.type !== "image/jpeg" && file.type !== "image/png") {
65 this.$message({
66 message: "只支持jpg、png格式的图片!",
67 type: "warning",
68 });
69 return false;
70 }
71 const isLt2M = file.size / 1024 / 1024 < 2;
72 if (!isLt2M) {
73 this.$message({
74 message: "上传文件大小不能超过 2MB!",
75 type: "warning",
76 });
77 return false;
78 }
79 },
80 // 上传成功
81 successHandle(response, file, fileList) {
82 this.mFileList = fileList;
83 if (response && response.code === 200) {
84 this.$message.success("图片上传成功!");
85 this.$emit("upload-success", response, file);
86 } else {
87 this.$message.error(response.msg);
88 }
89 },
90 changeHandle(file, fileList) {
91 if(file.response && file.response.code == 500) {
92 this.$emit("upload-error",file);
93 }
94 },
95 handleExceed(files, fileList) {
96 this.$message.warning("只能上传1张图片!");
97 },
98 },
99 };
100 </script>
101 <style lang="scss">
102 .upload .hidden .el-upload--picture-card {
103 display: none;
104 }
105 </style>

调用组件代码:

 1 <template>
2 <div>
3 <el-form ref="dataForm" label-width="80px">
4 <el-form-item label="封面" prop="cover" class="is-required">
5 <upload list-type="picture-card" :action="url" :accept="'.jpg,.png,.JPG,.PNG'" :fileList="fileList"
6 :limit="1" @upload-success="uploadFile" @upload-remove="removeFile" @upload-error="uploadError">
7 </upload>
8 </el-form-item>
9 </el-form>
10 </div>
11 </template>
12
13 <script>
14 import Upload from '../components/cover-upload/index.vue'
15 export default {
16 components: {
17 Upload
18 },
19 data() {
20 return {
21 url: "",
22 fileList: [],
23 }
24 },
25 methods: {
26 uploadUrl() {
27 this.url = "http://xxx.xxx.xxx.xxx:xxx/yyxt/admin/course/courseInfo/upload?token=075de0303b15a38833a30a7a3b494794"//上传图片的后台接口
28 },
29 uploadError(file) {
30 this.fileList = [];
31 },
32 uploadFile(response, file) {
33 this.fileList = [{
34 url: response.data,
35 }, ];
36 },
37 removeFile(file) {
38 this.fileList = [];
39 },
40 },
41 mounted() {
42 this.uploadUrl();
43 }
44 }
45 </script>

点击上传后的图片上的放大镜,显示图片大图

 
 

Vue + Element 自定义上传封面组件的更多相关文章

  1. vue + element 文件上传 并将文件转 base64

    当时有一个需求 是需要用到上传文件这个功能,并且需要将文件转为 base64 给到后台.网上找的全是啥图片转base64 肯定是因为这类需求比较常见.当时有点懵了.后面一想,都他娘是文件啊.然后就找到 ...

  2. vue element ui 上传 请求接口

    在页面上 http-request: 覆盖默认的上传行为,可以自定义上传的实现 <el-upload  class="avatar-uploader"  action=&qu ...

  3. Element ui 上传文件组件(单文件上传) 点击提交 没反应

    element ui 第一次上传文件后 上传其他文件再次点击不再次提交 需要使用 clearFiles 清空已上传文件列表 这时候在次点击 上传按钮 就会惊喜的发现 可以上传了使用方法 this.$r ...

  4. vue element upload上传、清除等

    如果项目中可以使用file-list,那我们可以点击file-list删除文件列表: 有时候项目中是不要这个文件列表的,所以在上传成功以后,文件列表一直存在,要重新上传就必须刷新页面,所以我们需要手动 ...

  5. vue ----element-ui 文件上传upload 组件 实现 及其后台

    1.前台 action 不用改 :https://jsonplaceholder.typicode.com/posts/ getFile: 获取文件 data(){ return { file: {} ...

  6. vue 阿里云上传组件

    vue 阿里云上传组件 Vue.js上传图片到阿里云OSS存储 测试项目git地址 本测试项目启动方法 示例链接 组件配置项 实践解释 本文主要介绍如何 在vue项目中使用web 直传方式上传阿里云o ...

  7. UI组件--element-ui--Upload多组件自定义上传

    需求: 提交详细信息的表单, 并上传对应图片(如下图), 后台接口要求表单数据和图片需要一次上传完成.. 分析: 实际上, 每个element-ui Upload组件都应发送一次请求, 很明显不符合我 ...

  8. AntD框架的upload组件上传图片时使用customRequest方法自定义上传行为

    本次做后台管理系统,采用的是 AntD 框架.涉及到图片的上传,用的是AntD的 upload 组件. 我在上一篇文章<AntD框架的upload组件上传图片时使用customRequest方法 ...

  9. vue-resource+element upload上传(遇到formData总是变为object格式)

    文件上传这种业务需求很常见,但是最近用了element,仔细看了文档,按照demo写了上传,与后台传参调取接口时,控制台总是显示未获取到文件,想了又想,发现一开始思路就跑遍了... 写此博记录下遇到的 ...

  10. vue中el-upload上传多图片且携带参数,批量而不是一张一张的解决方案

    现在前端基本不是vue技术栈就是react技术栈. vue技术栈最常用的就是element-ui的ui框架了. 在项目中,我们经常会碰到这种需求:批量上传文件 element-ui 确实也为我们提供了 ...

随机推荐

  1. ULID规范解读与实现原理

    前提 最近发现各个频道推荐了很多ULID相关文章,这里对ULID的规范文件进行解读,并且基于Java语言自行实现ULID,通过此实现过程展示ULID的底层原理. ULID出现的背景 ULID全称是Un ...

  2. Python学习笔记----操作字符串

    1.字符串相加.列表相加.列表和字符串不能混着使用 #序列相加 a="hello" b="python" c=a+b print("字符串相加的结果& ...

  3. 一天五道Java面试题----第十一天(分布式架构下,Session共享有什么方案--------->分布式事务解决方案)

    这里是参考B站上的大佬做的面试题笔记.大家也可以去看视频讲解!!! 文章目录 1.分布式架构下,Session共享有什么方案 2.简述你对RPC.RMI的理解 3.分布式id生成方案 4.分布式锁解决 ...

  4. LeetCode------找到所有数组中消失的数字(6)【数组】

    来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/find-all-numbers-disappeared-in-an-array 1.题目 找到 ...

  5. 漫谈Entity-Component-System

    原文链接 简介 对于很多人来说,ECS只是一个可以提升性能的架构,但是我觉得ECS更强大的地方在于可以降低代码复杂度. 在游戏项目开发的过程中,一般会使用OOP的设计方式让GameObject处理自身 ...

  6. Nginx配置-1

    1.绑定nginx到指定cpu [root@nginx conf.d]# vim /apps/nginx/conf/nginx.conf worker_processes 2; worker_cpu_ ...

  7. C# 9.0 添加和增强的功能【基础篇】

    一.记录(record) C# 9.0 引入了记录类型. 可使用 record 关键字定义一个引用类型,以最简的方式创建不可变类型.这种类型是线程安全的,不需要进行线程同步,非常适合并行计算的数据共享 ...

  8. 学习ASP.NET Core Blazor编程系列十——路由(下)

    学习ASP.NET Core Blazor编程系列一--综述 学习ASP.NET Core Blazor编程系列二--第一个Blazor应用程序(上) 学习ASP.NET Core Blazor编程系 ...

  9. [排序算法] 简单选择排序 (C++)

    简单选择排序原理 简单选择排序 SelectSort 是一种十分直观地排序方法.其原理是每次从未排序的元素中找到当前最小的元素,放在当前未排序序列的首位.一直重复操作直至最后未排序的元素个数为 0,即 ...

  10. Redis系列11:内存淘汰策略

    Redis系列1:深刻理解高性能Redis的本质 Redis系列2:数据持久化提高可用性 Redis系列3:高可用之主从架构 Redis系列4:高可用之Sentinel(哨兵模式) Redis系列5: ...