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 相关文章推荐
详解AngularJS中的依赖注入机制
Jun 17 Javascript
jQuery Ajax页面局部加载方法汇总
Jun 02 Javascript
浅谈JavaScript 函数参数传递到底是值传递还是引用传递
Aug 23 Javascript
关于Bootstrap按钮组件消除黄框的方法
May 19 Javascript
Vue computed计算属性的使用方法
Jul 14 Javascript
react native仿微信PopupWindow效果的实例代码
Aug 07 Javascript
js排序与重组的实例讲解
Aug 28 Javascript
JS设计模式之数据访问对象模式的实例讲解
Sep 30 Javascript
jQuery读取本地的json文件(实例讲解)
Oct 31 jQuery
在vue中使用jointjs的方法
Mar 24 Javascript
vue中的过滤器实例代码详解
Jun 06 Javascript
vue+echarts实现动态折线图的方法与注意
Sep 01 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
德生PL550的电路分析
2021/03/02 无线电
PHP 生成的XML以FLASH获取为乱码终极解决
2009/08/07 PHP
innerHTML 和 getElementsByName 在IE下面的bug 的解决
2010/04/09 Javascript
分享一个用Mootools写的鼠标滑过进度条改变进度值的实现代码
2011/12/12 Javascript
JavaScript中的连字符详解
2013/11/28 Javascript
JavaScript去除数组里重复值的方法
2015/07/13 Javascript
详解nodeJs文件系统(fs)与流(stream)
2018/01/24 NodeJs
vue3.0 CLI - 3.2 路由的初级使用教程
2018/09/20 Javascript
Nuxt.js 数据双向绑定的实现
2019/02/17 Javascript
react+redux仿微信聊天界面
2019/06/21 Javascript
[00:50]2014DOTA2国际邀请赛 NEWBEE战队回顾
2014/08/01 DOTA
python计算圆周长、面积、球体体积并画出圆
2014/04/08 Python
Python脚本实现集群检测和管理功能
2015/03/06 Python
python中urlparse模块介绍与使用示例
2017/11/19 Python
图解Python变量与赋值
2018/04/03 Python
浅谈Pycharm调用同级目录下的py脚本bug
2018/12/03 Python
selenium+python自动化测试之环境搭建
2019/01/23 Python
Python一个简单的通信程序(客户端 服务器)
2019/03/06 Python
详解Python连接MySQL数据库的多种方式
2019/04/16 Python
Win10下Python3.7.3安装教程图解
2019/07/08 Python
python+OpenCV实现车牌号码识别
2019/11/08 Python
pytorch中的卷积和池化计算方式详解
2020/01/03 Python
Python xlwt模块使用代码实例
2020/06/10 Python
Html5页面内使用JSON动画的实现
2019/01/29 HTML / CSS
Expedia爱尔兰:酒店、机票、租车及廉价假期
2017/01/02 全球购物
台湾最大网路书店:博客来
2018/03/18 全球购物
英国婴儿和儿童服装网站:Vertbaudet
2018/04/02 全球购物
自荐信的两点禁忌
2013/10/30 职场文书
电子商务自荐书范文
2014/01/04 职场文书
小学生演讲稿
2014/01/12 职场文书
安全施工责任书
2014/08/25 职场文书
股指期货心得体会
2014/09/13 职场文书
党的群众路线教育实践活动查摆问题及整改措施
2014/10/10 职场文书
寒假安全保证书
2015/02/28 职场文书
2015年英语教师工作总结
2015/05/20 职场文书
SpringBoot+Vue+JWT的前后端分离登录认证详细步骤
2021/09/25 Java/Android