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 学习笔记 选择器之二
Jul 23 Javascript
js解析与序列化json数据(二)序列化探讨
Feb 01 Javascript
js中浮点型运算BUG的解决方法说明
Jan 06 Javascript
JavaScript实现16进制颜色值转RGB的方法
Feb 09 Javascript
js强制把网址设为默认首页
Sep 29 Javascript
JavaScript setTimeout使用闭包功能实现定时打印数值
Dec 18 Javascript
json对象转为字符串,当做参数传递时加密解密的实现方法
Jun 29 Javascript
jQuery查找节点方法完整实例
Sep 13 Javascript
JavaScript 链式结构序列化详解
Sep 30 Javascript
bootstrap timepicker在angular中取值并转化为时间戳
Jun 13 Javascript
jQuery实现使用sort方法对json数据排序的方法
Apr 17 jQuery
详解Vue项目引入CreateJS的方法(亲测可用)
May 30 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生成excel列名超过26列大于Z时的解决方法
2014/12/29 PHP
如何解决PHP使用mysql_query查询超大结果集超内存问题
2016/03/14 PHP
Laravel6.2中用于用户登录的新密码确认流程详解
2019/10/16 PHP
页面版文本框智能提示JS代码
2009/11/20 Javascript
JavaScript高级程序设计阅读笔记(六) ECMAScript中的运算符(二)
2012/02/27 Javascript
jquery Tab效果和动态加载的简单实例
2013/12/11 Javascript
js通过八个点 拖动改变div大小的实现方法
2014/03/05 Javascript
jquery 3D 标签云示例代码
2014/06/12 Javascript
jQuery中:animated选择器用法实例
2014/12/29 Javascript
JavaScript动态修改网页元素内容的方法
2015/03/21 Javascript
在Node.js应用中使用Redis的方法简介
2015/06/24 Javascript
JS实现的在线调色板实例(附demo源码下载)
2016/03/01 Javascript
全屏js头像上传插件源码高清版
2016/03/29 Javascript
全面解析bootstrap格子布局
2016/05/22 Javascript
浅谈Node.js:Buffer模块
2016/12/05 Javascript
Vue.js组件间的循环引用方法示例
2017/12/27 Javascript
微信实现自动跳转到用其他浏览器打开指定APP下载
2019/02/15 Javascript
JS求解两数之和算法详解
2020/04/28 Javascript
vue实现下载文件流完整前后端代码
2020/11/17 Vue.js
[15:35]教你分分钟做大人:天怒法师
2014/10/30 DOTA
Python随机生成带特殊字符的密码
2016/03/02 Python
使用Python读取安卓手机的屏幕分辨率方法
2018/03/31 Python
Python爬虫的两套解析方法和四种爬虫实现过程
2018/07/20 Python
Python使用dict.fromkeys()快速生成一个字典示例
2019/04/24 Python
python实现串口自动触发工作的示例
2019/07/02 Python
python opencv实现图片缺陷检测(讲解直方图以及相关系数对比法)
2020/04/07 Python
opencv 形态学变换(开运算,闭运算,梯度运算)
2020/07/07 Python
matplotlib 使用 plt.savefig() 输出图片去除旁边的空白区域
2021/01/05 Python
英国汽车座椅和婴儿车购物网站:Uber Kids
2017/04/19 全球购物
法雷奥SQA(electric)面试问题
2016/01/23 面试题
门卫人员岗位职责
2013/12/24 职场文书
致200米运动员广播稿
2014/02/06 职场文书
报考公务员诚信承诺书
2014/08/29 职场文书
2015新员工试用期工作总结
2014/12/12 职场文书
安全先进个人材料
2014/12/29 职场文书
美德少年事迹材料(2016推荐版)
2016/02/25 职场文书