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基于jQuery的表格悬停变色/恢复,表格点击变色/恢复,点击行选Checkbox
Aug 05 Javascript
ajax 同步请求和异步请求的差异分析
Jul 04 Javascript
jqgrid 表格数据导出实例
Nov 21 Javascript
JavaScript计时器示例分析
Feb 05 Javascript
使用AOP改善javascript代码
May 01 Javascript
浅析Node.js的Stream模块中的Readable对象
Jul 29 Javascript
Bootstrap自定义文件上传下载样式
May 26 Javascript
vue.js从安装到搭建过程详解
Mar 17 Javascript
解决webpack打包速度慢的解决办法汇总
Jul 06 Javascript
简单实现jQuery上传图片显示预览功能
Jun 29 jQuery
vue-cli+iview项目打包上线之后图标不显示问题及解决方法
Oct 16 Javascript
vue项目中锚点定位替代方式
Nov 13 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判断字符以及字符串的包含方法属性
2008/08/30 PHP
php中防止SQL注入的最佳解决方法
2013/04/25 PHP
解析PHP汉字转换拼音的类
2013/06/18 PHP
PHP加Nginx实现动态裁剪图片方案
2014/03/10 PHP
PHP7下协程的实现方法详解
2017/12/17 PHP
css图片自适应大小
2007/11/28 Javascript
深入理解JavaScript系列(9) 根本没有“JSON对象”这回事!
2012/01/15 Javascript
用js判断页面刷新或关闭的方法(onbeforeunload与onunload事件)
2012/06/22 Javascript
node.js中的url.parse方法使用说明
2014/12/10 Javascript
jquery+ajax验证不通过也提交表单问题处理
2014/12/12 Javascript
javascript动态创建及删除元素的方法
2014/12/22 Javascript
详解基于javascript实现的苹果系统底部菜单
2016/12/02 Javascript
JS无缝滚动效果实现方法分析
2016/12/21 Javascript
JS 实现计算器详解及实例代码(一)
2017/01/08 Javascript
详解node中创建服务进程
2017/05/09 Javascript
基于hover的用法实例(推荐)
2017/07/04 Javascript
基于JavaScript实现前端数据多条件筛选功能
2020/08/19 Javascript
js提取中文拼音首字母的封装工具类
2018/03/12 Javascript
微信小程序实现人脸检测功能
2018/05/25 Javascript
讲解vue-router之什么是编程式路由
2018/05/28 Javascript
layui layer select 选择被遮挡的解决方法
2019/09/21 Javascript
js实现纯前端压缩图片
2020/11/16 Javascript
Django中更新多个对象数据与删除对象的方法
2015/07/17 Python
python将文本分每两行一组并保存到文件
2018/03/19 Python
Python自动化完成tb喵币任务的操作方法
2019/10/30 Python
python框架flask表单实现详解
2019/11/04 Python
利用python生成照片墙的示例代码
2020/04/09 Python
matplotlib制作雷达图报错ValueError的实现
2021/01/05 Python
Python 求向量的余弦值操作
2021/03/04 Python
岗位职责的含义
2013/11/17 职场文书
副总经理工作职责
2013/11/28 职场文书
机械系毕业生求职信
2014/05/28 职场文书
2014年党的群众路线活动个人整改措施
2014/10/28 职场文书
酒店收银员岗位职责
2015/04/07 职场文书
2015年工程师工作总结
2015/04/30 职场文书
TV动画《八十龟酱观察日记》第四季宣传PV公布
2022/04/06 日漫