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

                      
第一张图片是上传之前,第二张图片是上传成功后,第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. 01-MySQL8主从详解

    主从原理 master服务器将数据的改变记录二进制binlog日志,当master上的数据发生改变时,则将其改变写入二进制日志中:slave服务器会在一定时间间隔内对master二进制日志进行探测其是 ...

  2. 1.ElasticSearch系列之集群部署

    第一步:安装JDK JDK要求jdk1.8+,不安装也可以,ES自带JDK 第二步:系统配置 2.1 禁用交换区 sudo swapoff -a 2.2 开最大文件数的限制 编辑文件 /etc/sec ...

  3. cmd中pip加速的方法

    临时加速: pip install dlib -i https://pypi.tuna.tsinghua.edu.cn/simple/ 永久加速: 在user文件夹里新建pip文件夹,再建pip.in ...

  4. LcdTools如何自定义读写PX01 SSD2828寄存器

    LcdToos打开相应的工程文件,连接PX01并开启点亮屏使LcdTools开关处于开启状态. 切到"测试设置"栏,在"Bridge控制"栏,在"Ad ...

  5. 二、Celery执行一步任务

    二.Celery执行异步任务 2.1.基本使用 创建项目celerypro 创建异步任务执行文件celery_task: import celery import time backend='redi ...

  6. java学习之springboot

    0x00前言 呀呀呀时隔好久我又来做笔记了,上个月去大型保密活动了,这里在网上看了一些教程如果说不是去做java开发我就不做ssm的手动整合了采用springboot去一并开发. Spring Boo ...

  7. MySQL InnooDB引擎之并发事务问题以及隔离级别的作用和区别

    最近在复习MySQL事务,但网上很多博客和资料可以说讲的不是模棱两可就是只有文字描述不够形象易懂,下面通过我的学习来详细讲一讲事务并发都会引起哪些问题?以及隔离级别是什么?InnoDB引擎是如何通过隔 ...

  8. 2022ICPC区域赛参后感悟

    第一次参加正式的大类赛事,在某种程度上挺激动的.我呢,可以说是刚步入竞赛一年,在此期间遇见了一些志同道合的朋友,最重要的是遇见了我的队友. 开始前,我幻想过我们小队可以超常发挥,拿取学校中第一个区域赛 ...

  9. UBOOT编译--- include/config.h、 include/autoconf.mk、include/autoconf.mk.dep、u-boot.cfg(三)

    1. 前言 UBOOT版本:uboot2018.03,开发板myimx8mmek240. 2. 概述 本节主要接上一节解析 :include/config.h. include/autoconf.mk ...

  10. 快速构建页面结构的 3D Visualization

    对 Chrome 扩展功能熟悉的小伙伴,可能都有用过 Chrome 的 3D 展示页面层级关系这个功能. 可以通过 控制台 --> 右边的三个小点 --> More Tools --> ...