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 相关文章推荐
解放web程序员的输入验证
Oct 06 Javascript
jQuery 源码分析笔记(4) Ready函数
Jun 02 Javascript
面向对象的Javascript之三(封装和信息隐藏)
Jan 27 Javascript
鼠标放在图片上显示大图的JS代码
Mar 26 Javascript
js展开闭合效果演示代码
Jul 24 Javascript
如何创建一个JavaScript弹出DIV窗口层的效果
Sep 25 Javascript
jquery左右滚动焦点图banner图片鼠标经过显示上下页按钮
Oct 11 Javascript
JavaScript实现倒计时代码段Item1(非常实用)
Nov 03 Javascript
基于JavaScript代码实现pc与手机之间的跳转
Dec 23 Javascript
PHP实现本地图片上传和验证功能
Feb 27 Javascript
vue初尝试--项目结构(推荐)
Jan 30 Javascript
解决Layui 表格自适应高度的问题
Nov 15 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 数组和字符串互相转换实现方法
2013/03/26 PHP
PHP5全版本绕过open_basedir读文件脚本漏洞详细介绍
2015/01/20 PHP
PHP设计模式之适配器模式代码实例
2015/05/11 PHP
javascript之bind使用介绍
2011/10/09 Javascript
js算法中的排序、数组去重详细概述
2013/10/14 Javascript
jQuery+ajax实现文章点赞功能的方法
2015/12/31 Javascript
jQuery实现的调整表格行tr上下顺序
2016/01/10 Javascript
JavaScript+html5 canvas绘制渐变区域完整实例
2016/01/26 Javascript
Angular2 环境配置详细介绍
2016/09/21 Javascript
html判断当前页面是否在iframe中的实例
2016/11/30 Javascript
写jQuery插件时的注意点
2017/02/20 Javascript
80%应聘者都不及格的JS面试题
2017/03/21 Javascript
详解React Native 屏幕适配(炒鸡简单的方法)
2018/06/11 Javascript
原生JS检测CSS3动画是否结束的方法详解
2019/01/27 Javascript
python通过pil模块获得图片exif信息的方法
2015/03/16 Python
详解Django缓存处理中Vary头部的使用
2015/07/24 Python
python数据清洗系列之字符串处理详解
2017/02/12 Python
python开发利器之ulipad的使用实践
2017/03/16 Python
python 实现读取一个excel多个sheet表并合并的方法
2019/02/12 Python
Python求均值,方差,标准差的实例
2019/06/29 Python
jenkins配置python脚本定时任务过程图解
2019/10/29 Python
python实现自动化报表功能(Oracle/plsql/Excel/多线程)
2019/12/02 Python
查看keras的默认backend实现方式
2020/06/19 Python
python单例模式的应用场景实例讲解
2021/02/24 Python
CSS3哪些新特性值得称赞
2016/03/02 HTML / CSS
大学毕业生工作的自我评价
2013/10/01 职场文书
会计电算化个人自我评价
2013/11/17 职场文书
公司市场部岗位职责
2013/12/02 职场文书
入党申请自荐书范文
2014/02/11 职场文书
前处理班长职位说明书
2014/03/01 职场文书
在校实习生求职信
2014/06/18 职场文书
开服装店计划书
2014/08/15 职场文书
感恩教师节演讲稿
2014/09/03 职场文书
导游词之开封禹王台风景区
2019/12/02 职场文书
React + Threejs + Swiper 实现全景图效果的完整代码
2021/06/28 Javascript
HTML CSS 一个标签实现带动画的抖音LOGO
2022/04/26 HTML / CSS