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语言结构小记(一)
Sep 10 Javascript
简单的jquery拖拽排序效果实现代码
Sep 20 Javascript
中文字符串截取的js函数代码
Apr 17 Javascript
JavaScript使用DeviceOne开发实战(四)仿优酷视频应用
Dec 02 Javascript
Javascript实现图片轮播效果(二)图片序列节点的控制实现
Feb 17 Javascript
Node.js实用代码段之获取Buffer对象字节长度
Mar 17 Javascript
JS集成fckeditor及判断内容是否为空的方法
May 27 Javascript
基于jQuery实现数字滚动效果
Jan 16 Javascript
详解如何让InstantClick兼容MathJax、百度统计等
Sep 12 Javascript
AngularJS实现与后台服务器进行交互的示例讲解
Aug 13 Javascript
jQuery实现轮播图源码
Oct 23 jQuery
ajax jquery实现页面某一个div的刷新效果
Mar 04 jQuery
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注入实例
2006/10/09 PHP
PHP实现单例模式最安全的做法
2014/06/13 PHP
php-msf源码详解
2017/12/25 PHP
Laravel框架生命周期与原理分析
2018/06/12 PHP
PHP进阶学习之垃圾回收机制详解
2019/06/18 PHP
jQuery图片播放8款精美插件分享
2013/02/17 Javascript
JS 实现导航栏悬停效果(续)
2013/09/24 Javascript
iframe窗口高度自适应的实现方法
2014/01/08 Javascript
javascript计算用户打开网页的停留时间
2014/01/09 Javascript
JavaScript使用DeviceOne开发实战(三)仿微信应用
2015/12/02 Javascript
javascript正则表达式定义(语法)总结
2016/01/08 Javascript
jQuery获取与设置iframe高度的方法
2016/08/01 Javascript
JS实现的相册图片左右滚动完整实例
2016/11/23 Javascript
javascript十六进制数字和ASCII字符之间的转换方法
2016/12/27 Javascript
JavaScript使用ZeroClipboard操作剪切板
2017/05/10 Javascript
JavaScript动态绑定详解
2017/09/14 Javascript
React 实现拖拽功能的示例代码
2019/01/06 Javascript
JavaScript实现动态生成表格
2020/08/02 Javascript
Vue中添加滚动事件设置的方法详解
2020/09/14 Javascript
javascript实现简单留言板案例
2021/02/09 Javascript
[50:28]LGD女子学院第三期 DOTA2复仇之魂教学
2013/12/24 DOTA
[01:56]林书豪DOTA2上海特级锦标赛励志短片
2016/03/05 DOTA
Python内置数据类型详解
2014/08/18 Python
推荐11个实用Python库
2015/01/23 Python
使用Python生成url短链接的方法
2015/05/04 Python
详解python中的Turtle函数库
2018/11/19 Python
python如何实现代码检查
2019/06/28 Python
python实现滑雪者小游戏
2020/02/22 Python
PyCharm 在Windows的有用快捷键详解
2020/04/07 Python
解决jupyter运行pyqt代码内核重启的问题
2020/04/16 Python
策划总监岗位职责
2014/02/16 职场文书
党员公开承诺书和承诺事项
2014/03/25 职场文书
小学教师师德师风个人整改措施
2014/09/18 职场文书
2015年服务员个人工作总结
2015/05/27 职场文书
mysql优化
2021/04/06 MySQL
高端收音机+蓝牙音箱,JBL TUNER FM带收音蓝牙音箱评测
2021/04/24 无线电