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 相关文章推荐
jQuery示例收集
Nov 05 Javascript
将list转换为json失败的原因
Dec 17 Javascript
jquery获取元素索引值index()示例
Feb 13 Javascript
jQuery中outerHeight()方法用法实例
Jan 19 Javascript
分享纯手写漂亮的表单验证
Nov 19 Javascript
基于Node.js的JavaScript项目构建工具gulp的使用教程
May 20 Javascript
JavaScript必知必会(五) eval 的使用
Jun 08 Javascript
微信公众号  提示:Unauthorized API function 问题解决方法
Dec 05 Javascript
webpack热模块替换(HMR)/热更新的方法
Apr 05 Javascript
jQuery实现checkbox全选功能完整实例
Jul 12 jQuery
Node.js 路由的实现方法
Jun 05 Javascript
ant design vue中日期选择框混合时间选择器的用法说明
Oct 27 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面试常用算法(推荐)
2016/07/22 PHP
php5.3/5.4/5.5/5.6/7常见新增特性汇总整理
2020/02/27 PHP
PHP使用PhpSpreadsheet操作Excel实例详解
2020/03/26 PHP
Sample script that deletes a SQL Server database
2007/06/16 Javascript
jquery 表单取值常用代码
2009/12/22 Javascript
Extjs学习笔记之八 继承和事件基础
2010/01/08 Javascript
使用原生javascript创建通用表单验证——更锋利的使用dom对象
2011/09/13 Javascript
jquery插件bxslider用法实例分析
2015/04/16 Javascript
jQuery实现手机号码输入提示功能实例
2015/04/30 Javascript
js去除浏览器默认底图的方法
2015/06/08 Javascript
jquery层级选择器(匹配父元素下的子元素实现代码)
2016/09/05 Javascript
Node.js之网络通讯模块实现浅析
2017/04/01 Javascript
Angularjs单选框相关的示例代码
2017/08/17 Javascript
从setTimeout看js函数执行过程
2017/12/19 Javascript
Angular实现的简单查询天气预报功能示例
2017/12/27 Javascript
JavaScript实现放大镜效果代码示例
2020/04/29 Javascript
js实现双人五子棋小游戏
2020/05/28 Javascript
vue中可编辑树状表格的实现代码
2020/10/31 Javascript
nuxt 页面路由配置,主页轮播组件开发操作
2020/11/05 Javascript
python使用opencv读取图片的实例
2017/08/17 Python
python将控制台输出保存至文件的方法
2019/01/07 Python
Django 源码WSGI剖析过程详解
2019/08/05 Python
Pytorch抽取网络层的Feature Map(Vgg)实例
2019/08/20 Python
导致python中import错误的原因是什么
2020/07/01 Python
AmazeUI折叠式卡片布局,整合内容列表、表格组件实现
2020/08/20 HTML / CSS
迪卡侬英国官网:Decathlon英国
2017/04/08 全球购物
应聘自荐信
2013/12/14 职场文书
表彰先进集体通报
2014/01/12 职场文书
新年抽奖获奖感言
2014/03/02 职场文书
团日活动总结范文
2014/04/25 职场文书
优秀电子工程系毕业生求职信
2014/05/24 职场文书
北京天坛导游词
2015/02/12 职场文书
个人工作违纪检讨书
2015/05/05 职场文书
2015年中秋晚会主持稿
2015/07/30 职场文书
公司车辆维修管理制度
2015/08/05 职场文书
SQL Server使用T-SQL语句批处理
2022/05/20 SQL Server