canvas图片裁剪(使用canvas压缩图片上传的方法示例)
类别:Web前端 浏览量:1300
时间:2021-10-10 00:36:42 canvas图片裁剪
使用canvas压缩图片上传的方法示例因为原型图跟插件ui有出入,所以自己写了一个方法。。
首先得有一个上传按钮。
<input type="file" id="fileys" class="fileys" @change="uploadFile($event)" accept="image/*"/> <!--uploadFile用change是因为。用户可能会重复选其他图片-->
入正题:
uploadFile:function(event){ let file = event.target.files[0]; //获取input的图片file值 let param = new FormData(); // 创建form对象 if(param.getAll('file')[0] == "undefined"){ return false //判断是不是空 } let reader = new FileReader() reader.readAsDataURL(file) //读取文件并将文件以URL的形式保存在resulr属性中 base64格式 ,,,网上文档好像规定了格式。。我就选了一个base64 reader.onload = function(e) { // 文件读取完成时触发 let result = e.target.result // base64格式图片地址 var image = new Image() image.src = result // 设置image的地址为base64的地址 image.onload = function(){ var canvas = document.getElementById("canvas"); var context = canvas.getContext("2d"); canvas.width = image.width; // 设置canvas的画布宽度为图片宽度 canvas.height = image.height; context.drawImage(image, 0, 0, image.width, image.height) // 在canvas上绘制图片 let dataUrl = canvas.toDataURL('image/jpeg', 0.001) //设置压缩比,可根据需要设置,设置过小会影响图片质量,dataUrl 为压缩后的图片资源,可将其上传到服务器 let tupian = _this.dataURLtoFile(dataUrl, file.name) param.append('file', tupian);//对应后台接收图片名 //然后这里就可以写axios方法。去将这个param上传到后台 } } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
您可能感兴趣
- asp.net判断上传文件格式
- vsftpd详细配置(vsftpd匿名用户上传和下载的配置方法)
- vue3 动态生成组件(如何在vue3.0+中使用tinymce及实现多图上传文件上传公式编辑功能)
- html5导入图片文件(HTML5 实现图片上传预处理功能)
- django用户上传文件怎么接收(Django框架文件上传与自定义图片上传路径、上传文件名操作分析)
- 阿里云ecs实例详解(阿里云ecs服务器 修改php上传最大限制的方法)
- webview上传功能教程(关于webview适配H5上传照片或者视频文件的方法)
- js怎么上传压缩图片(如何用JS有效的压缩图片)
- ssis项目部署配置(基于SSIS 事件的向上传递详解)
- 云服务器怎么上传16g文件(云服务器怎么上传下载文件?)
- php上传文件的要求(PHP大文件分块上传功能实例详解)
- 搭建ftp服务器狗无法访问(护卫神主机大师创建网站后FTP无法上传的解决办法)
- 织梦数据库连接失败是什么意思(织梦上传服务器后数据连接失败问题的解决方法)
- laravel数据迁移(Laravel框架实现的上传图片到七牛功能详解)
- elementui自定义坐标(element-ui 上传图片后标注坐标点)
- php 大文件切片(PHP大文件切割上传功能实例分析)
- 开国中将,王牌军63军首任政委,两个连襟一个上将一个少将传为佳话(王牌军63军首任政委)
- 臭名昭著的731部队最高负责人 石井四郎(臭名昭著的731部队最高负责人)
- 王牌部队,你看的剧情我看的时尚(你看的剧情我看的时尚)
- 被鉴定的古董价值300万 当心,你可能遇到诈骗了(被鉴定的古董价值300万)
- 英语难学吗(初中英语难学吗)
- 如何追女孩子(如何追女孩子的技巧和方法)
热门推荐
- sass定时任务(sass简介_动力节点Java学院整理)
- laravel模型详解(laravel config文件配置全局变量的例子)
- springbootvue项目代码(Vue+SpringBoot实现支付宝沙箱支付的示例代码)
- docker里面安装redis(Docker上实现Redis集群搭建)
- iframe跨域原理(详解使用postMessage解决iframe跨域通信问题)
- css样式退出效果(纯css实现选中切换效果的示例)
- 如何获取存储过程返回值
- python使用pandas数据分析系列(python使用pandas处理大数据节省内存技巧推荐)
- python分支的描述(学习python分支结构)
- asp.net 文件操作
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9