1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > javascript – 在移动端怎样上传图片? 而且在上传前把图片压缩一定的大小?

javascript – 在移动端怎样上传图片? 而且在上传前把图片压缩一定的大小?

时间:2022-03-19 14:50:35

相关推荐

javascript – 在移动端怎样上传图片? 而且在上传前把图片压缩一定的大小?

后端开发|php教程

javascript,php,html

后端开发-php教程

在移动端怎样上传图片?,而且在上传前把图片压缩一定的大小?

泰捷视频源码,ubuntu var是什么,调用tomcat的线程池,长沙爬虫ip,php能写后端嘛,seo 推广SEO优化lzw

易语言收费辅助源码,ubuntu显示详细关机,网络爬虫问题背景,member php,seo入门介绍lzw

回复内容:

信息 管理 源码,ubuntu怎么装php,tomcat占内存非常大,方舟巨型爬虫,php中写性别和年龄,seo定向方式lzw

在移动端怎样上传图片?,而且在上传前把图片压缩一定的大小?

对于异步上传来说,如果仍想用文件直接上传方法的话,可以采用HTML5的FormData,具体操作可以参考这篇博客。/lhb25/…

本人还有另外一种异步上传图片的方法。先将图片转换成base64字符串,然后再把base64字符串提交到服务器上,服务器接收后,可以再用具体的API将base64字符串转换成图片内容。以下为具体实现方法:

var getObjectURL = function(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; }

getObjectURL方法用于将传入的input中的图片file对象,转换成一个临时的url,而这个url是同域的。

var converImgTobase64 = function(url, callback, outputFormat) { var canvas = document.createElement(CANVAS), ctx = canvas.getContext(2d), img = new Image; img.crossOrigin = Anonymous; img.onload = function(){ canvas.height = img.height; canvas.width = img.width; ctx.drawImage(img,0,0); var dataURL = canvas.toDataURL(outputFormat || image/png); callback.call(this, dataURL); canvas = null; }; img.src = url; }

converImgTobase64方法就是将上面所得到的url传入,通过canvasAPI转换成base64字符串,注意这个url必须是同域的,不可跨域,所以getObjectURL这个方法是很有必要的。

例子:

var input = $("input[type=file]")[0], src = getObjectURL(input.files[0]);converImgTobase64(src, function(base64Str) { //处理base64Str相关的callback,可以直接在这里发送ajax请求。});

这部分组件的代码在本人的一个util库中,欢迎参考并提出整改意见~~~/zero-mo/Br…

另外,图片压缩的话,这里有一个是基于canvas进行操作的,你可以试一下。

/xiao-y…

以下引用我之前的回答

至于压缩的话,剪裁之后的图片大小自然比原图小很多

原问题地址:/q/10…

刚写的文章:

/a/11…

主要是用原生的HTML5文件表单选择,然后用插件压缩,最后直接用插件输出的FormData上传。

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