700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > 在cropper中js通过vue的图片裁剪上传功能如何实现

在cropper中js通过vue的图片裁剪上传功能如何实现

时间:2023-07-05 18:31:04

相关推荐

在cropper中js通过vue的图片裁剪上传功能如何实现

web前端|js教程

javascript,cropper,上传

web前端-js教程前些日子做了一个项目关于vue项目需要头像裁剪上传功能,看了一篇文章,在此基础上做的修改完成了这个功能,与大家分享一下。原文:/article/135719.htm

怎么下载网站的源码,vscode怎么把小灯泡,ubuntu桌面不见,tomcat不用80端口,云搜爬虫,php 离线手册,seo的定义特点和内容,网站右边悬浮代码,雷风影视cms模板lzw

首先下载引入cropper js,

进出口erp系统源码,vscode能返回吗,ubuntu 安装gm,tomcat显示日志命令,sqlite可视化客户端,爬虫妖女卡组新卡中文版多少钱,php 字符转ascii,兴义seo优化推广公司,网软交友婚恋网站正式版,用excel管理订单和发货模板lzw

npm install cropper js --save

在需要的页面引入:import Cropper from "cropper js"

h5网站 案例 源码下载,ubuntu升级go版本,tomcat配置4g内存,爬虫系统方案,php绘图用的函数有,未备案seolzw

html的代码如下:

主要是js代码,如下

1,data里面定好初始变量,绑定数据,imgCropperData是我定义的判断图片格式的。

data() { return { headerImage: "", picValue: "", cropper: "", croppable: false, panel: false, url: "", imgCropperData: { accept: "image/gif, image/jpeg, image/png, image/jpg" } }; }

2,在mounted里面初始换裁剪框

mounted() { //初始化这个裁剪框 var self = this; var image = document.getElementById("image"); this.cropper = new Cropper(image, { aspectRatio: 1, viewMode: 1, background: false, zoomable: false, ready: function() { self.croppable = true; } }); }

3.methods的方法比较多,包括创建URL路径,input框change事件,canvas画图,确定提交上传。我还加了取消事件函数,判断上传文件的类型和大小。

methods: { //取消上传 cancel() { this.panel = false; var obj = document.getElementById(change) ; obj.outerHTML=obj.outerHTML; }, //创建url路径 getObjectURL(file) { var url = null; if (window.createObjectURL != undefined) { // basic url = window.createObjectURL(file); } else if (window.URL != undefined) { // mozilla(firefox) url = window.URL.createObjectURL(file); } else if (window.webkitURL != undefined) { // webkit or chrome url = window.webkitURL.createObjectURL(file); } return url; }, //input框change事件,获取到上传的文件 change(e) { let files = e.target.files || e.dataTransfer.files; if (!files.length) return; let type = files[0].type; //文件的类型,判断是否是图片 let size = files[0].size; //文件的大小,判断图片的大小 if (this.imgCropperData.accept.indexOf(type) == -1) { alert("请选择我们支持的图片格式!"); return false; } if (size > 5242880) { alert("请选择5M以内的图片!"); return false; } this.picValue = files[0]; this.url = this.getObjectURL(this.picValue); //每次替换图片要重新得到新的url if (this.cropper) { this.cropper.replace(this.url); } this.panel = true; }, //确定提交 commit() { this.panel = false; var croppedCanvas; var roundedCanvas; if (!this.croppable) { return; } // Crop croppedCanvas = this.cropper.getCroppedCanvas(); // Round roundedCanvas = this.getRoundedCanvas(croppedCanvas); this.headerImage = roundedCanvas.toDataURL(); //上传图片 this.postImg(); }, //canvas画图 getRoundedCanvas(sourceCanvas) { var canvas = document.createElement("canvas"); var context = canvas.getContext("2d"); var width = sourceCanvas.width; var height = sourceCanvas.height; canvas.width = width; canvas.height = height; context.imageSmoothingEnabled = true; context.drawImage(sourceCanvas, 0, 0, width, height); context.globalCompositeOperation = "destination-in"; context.beginPath(); context.arc( width / 2, height / 2, Math.min(width, height) / 2, 0, 2 * Math.PI, true ); context.fill(); return canvas; }, //提交上传函数 postImg() { alert("上传成功"); //这边写图片的上传 } }

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

如何在vue2中设置全局变量?(详细教学)

如何在JS中实现字符串拼接的功能(扩展String.prototype.format)

利用ES6通过WeakMap解决内存泄漏问题(详细教学)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。