el-upload文件上传组件
一、介绍
element-ui的组件之一,用来点击上传文件
官方是使用 before-upload 限制用户上传的图片格式和大小。但是某些浏览器不支持此方法,所以使用on-change来代替。
二、代码
<template>
<!--选择图片-->
<el-upload
style="width: 100%;"
action="/"
class="avatar-uploader"
accept="image/*"
:auto-upload="false"
:show-file-list="false"
:on-change="selectPic">
<img v-if="imgUrl" :src="imgUrl" class="avatar">
<div v-else class="avatar-uploader-icon">
<div style="padding-bottom: 20px">
<img :src="back||'/static/media/imgUpload.png'" height="80" style="margin-bottom: 10px;margin-top: 30px">
<br>
<span style="line-height: 20px"> {{text}}</span>
</div>
</div>
</el-upload>
</template>
<script>
export default {
name: "selectImg",
data() {
return {}
},
props: ['imgUrl', 'text', 'back'],
created() {
},
methods: {
selectPic(file) {
this.GetPicFileBase64(file, (base64) => {
this.$emit('select', base64.split(',')[1], file)
})
return false
}
}
}
</script> <style>
.avatar-uploader .el-upload {
border: 1px dashed #d9d9d9;
border-radius: 5px;
cursor: pointer;
display: block;
box-sizing: border-box;
overflow: hidden;
} .avatar-uploader .el-upload:hover {
border-color: rgb(245, 207, 150);
} .avatar-uploader-icon {
font-size: 20px;
color: #8c939d;
margin: 8px;
background: rgb(216, 234, 242);
border-radius: 5px;
box-sizing: border-box;
} .avatar {
width: 100%;
display: block;
}
</style>
//图片上传处理
Vue.prototype.GetPicFileBase64 = function (file, callback) {
let load = (base64) => {
if (base64 && file.raw.size < (this.$store.state.max_pic_size * 1024 * 1024) && file.raw.type.match("image")) {
callback(base64)
} else {
alert(`请检查图片文件类型,大小不超过${this.$store.state.max_pic_size}MB`)
}
}
let err = (e) => {
this.Log(e)
alert("读取文件失败,请检查浏览器设置重试")
}
let base64 = ''
if (Image) {
let Img = new Image();
Img.src = file.url;
Img.onload = () => {
let width = Img.width;
let height = Img.height;
let canvas = document.createElement("canvas");
canvas.width = width;
canvas.height = height;
canvas.getContext("2d").drawImage(Img, 0, 0, width, height);
base64 = canvas.toDataURL('image/jpeg', 0.8);
load(base64)
}
Img.onerror = err
} else if (FileReader) {
let fr = new FileReader()
fr.readAsDataURL(file.raw)
fr.onerror = err
fr.onload = (e) => {
base64 = e.target.result
load(base64)
}
} else {
alert("您的设备有不兼容的功能,请更换浏览器重试或联系客服")
return
}
}
el-upload文件上传组件的更多相关文章
- Vue.js 3.0搭配.NET Core写一个牛B的文件上传组件
在开发Web应用程序中,文件上传是经常用到的一个功能. 在Jquery时代,做上传功能,一般找jQuery插件就够了,很少有人去探究上传文件插件到底是怎么做的. 简单列一下我们要做的技术点和功能点 使 ...
- Atitit..文件上传组件选型and最佳实践总结(2)----断点续传
Atitit..文件上传组件选型and最佳实践总结(2)----断点续传 1. 断点续传的原理 1 2. 如何判断一个插件/控件是否支持断点续传?? 1 3. 常用的组件选型结果::马 1 4. 自定 ...
- ASP中文件上传组件ASPUpload介绍和使用方法
[导读]要实现该功能,就要利用一些特制的文件上传组件.文件上传组件网页非常多,这里介绍国际上非常有名的ASPUpload组件 1 下载和安装ASPUpload 要实现该功能,就要利用一些特制的文件上 ...
- Atitit..文件上传组件选择and最佳实践的总结(2)----HTTP
Atitit..文件上传组件选型and最佳实践总结(2)----断点续传 1. 断点续传的原理 1 2. 怎样推断一个插件/控件是否支持断点续传?? 1 3. 经常使用的组件选型结果::马 1 4. ...
- 文件上传组件FileUpload 以及邮箱搭建JavaMail
文件上传与下载 1.1 文件上传 案例: 注册表单/保存商品等相关模块! --à 注册选择头像 / 商品图片 (数据库:存储图片路径 / 图片保存到服务器中指定的目录) 文件上传,要点: 前台: 1 ...
- Baidu WebUploader 前端文件上传组件的使用
简介 WebUploader是由Baidu WebFE(FEX)团队开发的一个简单的以HTML5为主,FLASH为辅的现代文件上传组件.在现代的浏览器里面能充分发挥HTML5的优势,同时又不摒弃主流I ...
- BootStrap fileinput.js文件上传组件实例代码
1.首先我们下载好fileinput插件引入插件 ? 1 2 3 <span style="font-size:14px;"><link type="t ...
- Bootstrap fileinput.js,最好用的文件上传组件
本篇介绍如何使用bootstrap fileinput.js(最好用的文件上传组件)来进行图片的展示,上传,包括springMVC后端文件保存. 一.demo 二.插件引入 <link ty ...
- Commons FileUpload文件上传组件
Java实现的文件上传组件有好几种,其中最为“官方”的要数Apache Commons库中的FileUpload了吧. 页面 <form method="POST" enct ...
- jQuery.uploadify文件上传组件实例讲解
1.jquery.uploadify简介 在ASP.NET中上传的控件有很多,比如.NET自带的FileUpload,以及SWFUpload,Uploadify等等,尤其后面两个控件的用户体验比较好, ...
随机推荐
- Vue双向数据绑定原理深度解析
首先,什么是双向数据绑定?Vue是三大MVVM框架之一,数据绑定简单来说,就是当数据发生变化时,相应的视图会进行更新,当视图更新时,数据也会跟着变化. 在分析其原理和代码的时候,大家首先了解如下几个j ...
- Html+css编写太阳星系
我们都知道太阳系是以太阳为中心的,和所有受到太阳的引力约束天体的集合体.包括八大行星(由离太阳从近到远的顺序:水星.金星.地球.火星.木星.土星.天王星.海王星),而我用html和css所写的就是八大 ...
- 转: Meshlab简介
本文翻译自Meshlab主页:http://www.meshlab.net/ MeshLab是用于处理和编辑3D三角形网格的开源系统.它提供了一组用于编辑,清理,修复,检查,渲染,纹理和转换网格的工具 ...
- json条件查询
完整Demo <html> <head> <script type="text/javascript" src="http://www.w3 ...
- unicode_stop - 撤销控制台unicode模式(例如, 回到8-bit模式).
总览 unicode_stop 描述 unicode_stop 撤销以前 unicode_start(1) 命令的效果, 将显示屏和键盘设回到 8-bit 模式.
- 标准 IO 测试 标准输出,输入,出错缓冲大小;全缓冲文本流大小
例子:测试缓冲区大小 #include <stdio.h> int main(int argc, const char *argv[]) { //标准输入大小,没有输入内容时,标准输入缓冲 ...
- struts2注解方式的验证
struts2的验证分为分编程式验证.声明式验证.注解式验证.因现在的人越来越懒,都追求零配置,所以本文介绍下注解式验证. 一.hello world 参考javaeye的这篇文章,按着做一次,起码有 ...
- 关于springboot错误:“找不到或无法加载主类”的解决办法
我从网上找的一个Demo,运行的时候报 错误:“找不到或无法加载主类”,百度了一番,都是说在项目目录打开cmd,使用 mvn install.mvn clean complie之类的命令,都成功了,但 ...
- 50. Set接口和Set的实现类HashSet
集合分类:-------------------| Collection 单列集合的根接口 ---------------| List 如果实现了List接口的集合类,具备的特点是:有序,可重复- ...
- 「题解」:x
问题 A: x 时间限制: 1 Sec 内存限制: 256 MB 题面 题面谢绝公开. 题解 赛时想到了正解并且对拍了很久.对拍没挂,但是评测姬表示我w0了……一脸懵逼. 不难证明,如果对于两个数字 ...