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基础学习资料
Nov 23 Javascript
模拟select的代码
Oct 19 Javascript
可以用鼠标拖动的DIV实现思路及代码
Oct 21 Javascript
获取中文字符串的实际长度代码
Jun 05 Javascript
JavaScript设计模式之观察者模式(发布者-订阅者模式)
Sep 24 Javascript
jQuery的css()方法用法实例
Dec 24 Javascript
javascript中DOM复选框选择用法实例
May 14 Javascript
浅谈node中的exports与module.exports的关系
Aug 01 Javascript
详解vue 计算属性与方法跟侦听器区别(面试考点)
Apr 23 Javascript
使用Vue自定义指令实现Select组件
May 24 Javascript
Vue实现用户自定义字段显示数据的方法
Aug 28 Javascript
JavaScript如何优化逻辑判断代码详解
Jun 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
PHP4和PHP5共存于一系统
2006/11/17 PHP
php基础知识:类与对象(2) 自动加载对象
2006/12/13 PHP
PHP中include()与require()的区别说明
2010/03/10 PHP
php自定义session示例分享
2014/04/22 PHP
PHP+MySQL实现的简单投票系统实例
2016/02/24 PHP
PHP Socket网络操作类定义与用法示例
2017/08/30 PHP
用Laravel Sms实现laravel短信验证码的发送的实现
2018/11/29 PHP
jquery批量控制form禁用的代码
2013/08/06 Javascript
利用JS解决ie6不支持max-width,max-height问题的方法
2014/01/02 Javascript
Js获取下拉框选定项的值和文本的实现代码
2014/02/26 Javascript
JS+CSS实现自动切换的网页滑动门菜单效果代码
2015/09/14 Javascript
基于Bootstrap的Metronic框架实现页面链接收藏夹功能
2016/08/29 Javascript
js防刷新的倒计时代码 js倒计时代码
2017/09/06 Javascript
js实现控制文件拖拽并获取拖拽内容功能
2018/02/17 Javascript
Vue.JS实现垂直方向展开、收缩不定高度模块的JS组件
2018/06/19 Javascript
vue移动端轻量级的轮播组件实现代码
2018/07/12 Javascript
vue实现顶部菜单栏
2020/11/08 Javascript
elementui实现预览图片组件二次封装
2020/12/29 Javascript
Flask SQLAlchemy一对一,一对多的使用方法实践
2013/02/10 Python
python使用pyhook监控键盘并实现切换歌曲的功能
2014/07/18 Python
python 在屏幕上逐字显示一行字的实例
2018/12/24 Python
在 Jupyter 中重新导入特定的 Python 文件(场景分析)
2019/10/27 Python
python十进制转二进制的详解
2020/02/07 Python
CHARLES & KEITH英国官网:新加坡时尚品牌
2018/07/04 全球购物
Molton Brown美国官网:奢华美容、香水、沐浴和身体护理
2020/09/02 全球购物
某公司的.net工程师面试题笔试题
2013/11/22 面试题
怎样写好自荐信和推荐信
2013/12/26 职场文书
酒店前厅员工辞职信
2014/01/08 职场文书
商场拾金不昧表扬信
2014/01/13 职场文书
餐厅销售主管职责范本
2014/02/19 职场文书
葬礼司仪主持词
2014/03/31 职场文书
教师竞聘演讲稿
2014/05/16 职场文书
小学国旗下的演讲稿
2014/08/28 职场文书
检讨书1000字
2014/10/11 职场文书
2015年教师自我评价范文
2015/03/04 职场文书
2015中秋节晚会主持词
2015/07/01 职场文书