js+canvas实现图片格式webp/png/jpeg在线转换


Posted in Javascript onAugust 22, 2020

功能需求:
我们在网页中上传一张图片,选择不同的格式,将该图片转换为对应的格式。

实现思路:
实现这样的功能,使用后端语言【php,java等】可以很容易的完成。但是如果只在前端如何完成呢?

1、通过input上传图片,使用FileReader将文件读取到内存中。

2、将图片转换为canvas,canvas.toDataURL()方法设置为我们需要的格式,如:"image/webp","image/jpeg","image/png"。

3、最后将canvas转换为图片,显示在网页中。点击右键保存,就得到了不同格式的图片了。

toDataURL说明:
方法返回一个包含图片展示的 data URI 。可以使用 type 参数其类型,默认为 PNG 格式。图片的分辨率为96dpi。

语法:

canvas.toDataURL(type, encoderOptions);

type【可选】 图片格式,默认为 image/png,可选格式:"image/webp","image/jpeg","image/png"。

encoderOptions【可选】在指定图片格式为 image/jpeg 或 image/webp的情况下,可以从 0 到 1 的区间内选择图片的质量。如果超出取值范围,将会使用默认值 0.92。其他参数会被忽略。

注意点:

1、如果画布的高度或宽度是0,那么会返回字符串“data:,”。

2、其中webkit内核浏览器支持“image/webp”类型 。 建议使用Chrome浏览器。

代码例子:

html:

<input type="file" id="inputimg">
<select id="myselect">
	<option value="1">webp格式</option>
  <option value="2">jpeg格式</option>
  <option value="3">png格式</option> 
</select>
<button id="start">开始转换</button>
<p>预览:</p>
<img id="imgShow" src="" alt="">

js:

/*事件*/
document.getElementById('start').addEventListener('click', function(){
	getImg(function(image){
		var can=imgToCanvas(image),
		  imgshow=document.getElementById("imgShow");
		imgshow.setAttribute('src',canvasToImg(can));
	});
});
// 把image 转换为 canvas对象 
function imgToCanvas(image) { 	
  var canvas = document.createElement("canvas"); 
  canvas.width = image.width; 
  canvas.height = image.height;  
  canvas.getContext("2d").drawImage(image, 0, 0);  
  return canvas; 
} 
//canvas转换为image
function canvasToImg(canvas) {
	var array=["image/webp","image/jpeg","image/png"],
	  type=document.getElementById('myselect').value-1;
  var src = canvas.toDataURL(array[type]);
  return src;
}
//获取图片信息
function getImg(fn){
	var imgFile = new FileReader();
	try{
		imgFile.onload = function(e) {
			var image = new Image();
			image.src= e.target.result; //base64数据 
			image.onload=function(){
				fn(image);
			}
		}
		imgFile.readAsDataURL(document.getElementById('inputimg').files[0]);
	}catch(e){
		console.log("请上传图片!"+e);
	}
}

在线Demo:

地址:https://3water.com/tools/webp.html

说明:需要在chrome浏览器中使用,大家可以自行发挥可以做个批量转换。

到此这篇关于js+canvas实现图片格式webp/png/jpeg在线转换的文章就介绍到这了,更多相关webp/png/jpeg在线转换内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
浅谈关于JavaScript API设计的一些建议和准则
Jun 24 Javascript
jQuery实现仿新浪微博浮动的消息提示框(可智能定位)
Oct 10 Javascript
JS数组合并push与concat区别分析
Dec 17 Javascript
Javascript将双字节字符转换成单字节字符并计算长度
Jun 22 Javascript
Bootstrap零基础入门教程(三)
Jul 18 Javascript
js改变html的原有内容实现方法
Oct 05 Javascript
关于webuploader插件使用过程遇到的小问题
Nov 07 Javascript
JavaScript数组和对象的复制
Mar 21 Javascript
node版本管理工具n包使用教程详解
Nov 09 Javascript
js控制随机数生成概率代码实例
Mar 21 Javascript
vue 实现tab切换保持数据状态
Jul 21 Javascript
如何在面试中手写出javascript节流和防抖函数
Oct 22 Javascript
JavaScript中的函数式编程详解
Aug 22 #Javascript
微信小程序中data-key属性之数据传输(经验总结)
Aug 22 #Javascript
Vue 电商后台管理项目阶段性总结(推荐)
Aug 22 #Javascript
vue实现移动端H5数字键盘组件使用详解
Aug 25 #Javascript
探究一道价值25k的蚂蚁金服异步串行面试题
Aug 21 #Javascript
js实现页面导航层级指示效果
Aug 25 #Javascript
js实现拖拽元素选择和删除
Aug 25 #Javascript
You might like
php安全配置记录和常见错误梳理(总结)
2017/03/28 PHP
浅谈PHP发送HTTP请求的几种方式
2017/07/25 PHP
SCP远程VPS快速搬家和WDCP升级php5.3安装memcached和eaccelerator教程
2017/07/27 PHP
Laravel5.7 数据库操作迁移的实现方法
2019/04/12 PHP
PHP查找一列有序数组是否包含某值的方法
2020/02/07 PHP
php + ajax 实现的写入数据库操作简单示例
2020/05/16 PHP
JavaScript 的方法重载效果
2009/08/07 Javascript
javascript实现面向对象类的功能书写技巧
2010/03/07 Javascript
js 纯数字不重复排列的另类方法
2010/07/17 Javascript
jquery DIV撑大让滚动条滚到最底部代码
2013/06/06 Javascript
jquery ajax 简单范例(界面+后台)
2013/11/19 Javascript
Jquery倒计时源码分享
2014/05/16 Javascript
node.js中的fs.writeFileSync方法使用说明
2014/12/14 Javascript
js正则表达式replace替换变量方法
2016/05/21 Javascript
基于JS实现导航条之调用网页助手小精灵的方法
2016/06/17 Javascript
jQuery中text() val()和html()的区别实例详解
2016/06/28 Javascript
JavaScript中数组的22种方法必学(推荐)
2016/07/20 Javascript
JavaScript利用正则表达式替换字符串中的内容
2016/12/12 Javascript
javascript动画系列之模拟滚动条
2016/12/13 Javascript
jQuery无缝轮播图代码
2016/12/22 Javascript
jQuery实现简单弹窗遮罩效果
2017/02/27 Javascript
vue中如何实现pdf文件预览的方法
2018/07/12 Javascript
微信小程序form表单组件示例代码
2018/07/15 Javascript
[51:00]Secret vs VGJ.S 2018国际邀请赛淘汰赛BO3 第一场 8.24
2018/08/25 DOTA
python单链表实现代码实例
2013/11/21 Python
使用Python多线程爬虫爬取电影天堂资源
2016/09/23 Python
我喜欢你 抖音表白程序python版
2019/04/07 Python
Pytorch使用MNIST数据集实现CGAN和生成指定的数字方式
2020/01/10 Python
Python Selenium操作Cookie的实例方法
2021/02/28 Python
英国网上香水店:Fragrance Direct
2016/07/20 全球购物
社会实践心得体会
2014/01/03 职场文书
群众路线党课主持词
2014/04/01 职场文书
财务管理专业求职信
2014/06/11 职场文书
国贸专业求职信
2014/06/28 职场文书
go select编译期的优化处理逻辑使用场景分析
2021/06/28 Golang
python实现简单聊天功能
2021/07/07 Python