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 相关文章推荐
JS的数组的扩展实例代码
Jul 09 Javascript
从零开始学习jQuery (二) 万能的选择器
Oct 01 Javascript
ASP.NET jQuery 实例17 通过使用jQuery validation插件校验ListBox
Feb 03 Javascript
HTML复选框和单选框 checkbox和radio事件介绍
Dec 12 Javascript
VC调用javascript的几种方法(推荐)
Aug 09 Javascript
微信小程序 animation API详解及实例代码
Oct 08 Javascript
Bootstrap面板(Panels)的简单实现代码
Mar 17 Javascript
ES5学习教程之Array对象
Apr 01 Javascript
Bootstrap滚动监听组件scrollspy.js使用方法详解
Jul 20 Javascript
react国际化化插件react-i18n-auto使用详解
Mar 31 Javascript
Electron整合React使用搭建开发环境的步骤详解
Jun 07 Javascript
vue中后端做Excel导出功能返回数据流前端的处理操作
Sep 08 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模拟SQL Server的两个日期处理函数
2006/10/09 PHP
PHP实现分页的一个示例
2006/10/09 PHP
mysql中存储过程、函数的一些问题
2007/02/14 PHP
PHP验证信用卡卡号是否正确函数
2015/05/27 PHP
php事务回滚简单实现方法示例
2017/03/28 PHP
关于文本限制字数的js代码
2007/04/02 Javascript
javascript使用switch case实现动态改变超级链接文字及地址
2014/12/16 Javascript
node.js集成百度UE编辑器
2015/02/05 Javascript
利用jQuery设计一个简单的web音乐播放器的实例分享
2016/03/08 Javascript
js获取腾讯视频ID的方法
2016/10/03 Javascript
jquery延迟对象解析
2016/10/26 Javascript
jQuery实现导航高亮的方法【附demo源码下载】
2016/11/09 Javascript
js实现网页的两个input标签内的数值加减(示例代码)
2017/08/15 Javascript
vue组件中的数据传递方法
2018/05/14 Javascript
使用Vue实现简单计算器
2020/02/25 Javascript
JavaScript中while循环的基础使用教程
2020/08/11 Javascript
[01:35]2014DOTA2西雅图邀请赛 专访狐狸妈青春献给刀塔
2014/07/08 DOTA
[02:32]DOTA2完美大师赛场馆静安体育中心观赛全攻略
2017/11/08 DOTA
Python控制键盘鼠标pynput的详细用法
2019/01/28 Python
python调用matlab的m自定义函数方法
2019/02/18 Python
Python 分享10个PyCharm技巧
2019/07/13 Python
使用PYTHON解析Wireshark的PCAP文件方法
2019/07/23 Python
Python Django简单实现session登录注销过程详解
2019/08/06 Python
Django实现分页显示效果
2019/10/31 Python
使用Python防止SQL注入攻击的实现示例
2020/05/21 Python
a标签下载链接的简单实现
2016/09/13 HTML / CSS
高级运动鞋:GREATS
2019/07/19 全球购物
酒店工作职员求职简历的自我评价
2013/10/23 职场文书
区域总监的岗位职责
2013/11/21 职场文书
亲子运动会的活动方案
2014/08/17 职场文书
讲党性心得体会
2014/09/03 职场文书
坎儿井导游词
2015/02/09 职场文书
2015教师个人德育工作总结
2015/07/22 职场文书
2016年七夕爱情寄语
2015/12/04 职场文书
导游词之云南丽江古城
2019/09/17 职场文书
MySQL聚簇索引和非聚簇索引的区别详情
2022/06/14 MySQL