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 相关文章推荐
用JavaScript和注册表脚本实现右键收藏Web页选中文本
Jan 28 Javascript
JavaScript中的document.referrer在各种浏览器测试结果
Jul 18 Javascript
使用AOP改善javascript代码
May 01 Javascript
jquery简单实现外部链接用新窗口打开的方法
May 30 Javascript
简介JavaScript中Boolean.toSource()方法的使用
Jun 05 Javascript
bootstrap模态框垂直居中效果
Dec 03 Javascript
使用bat打开多个cmd窗口执行gulp、node
Feb 17 Javascript
Bootstrap栅格系统简单实现代码
Mar 06 Javascript
Bootstrap进度条实现代码解析
Mar 07 Javascript
JavaScript函数节流的两种写法
Apr 07 Javascript
微信小程序实现录音时的麦克风动画效果实例
May 18 Javascript
vue实现可以快进后退的跑马灯组件
Apr 08 Vue.js
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
桌面中心(三)修改数据库
2006/10/09 PHP
探讨:如何通过stats命令分析Memcached的内部状态
2013/06/14 PHP
php之curl设置超时实例
2014/11/03 PHP
php中strtotime函数用法详解
2014/11/15 PHP
php+mysql结合Ajax实现点赞功能完整实例
2015/01/30 PHP
codeigniter发送邮件并打印调试信息的方法
2015/03/21 PHP
php实现mysql数据库分表分段备份
2015/06/18 PHP
jQuery 使用手册(一)
2009/09/23 Javascript
IE关闭时判断及AJAX注销案例学习
2013/02/18 Javascript
浅析js设置控件的readonly与enabled属性问题
2013/12/25 Javascript
谈谈我对JavaScript原型和闭包系列理解(随手笔记8)
2015/12/24 Javascript
jQuery电话号码验证实例
2017/01/05 Javascript
angular实现表单验证及提交功能
2017/02/01 Javascript
jQuery EasyUI 选项卡面板tabs的使用实例讲解
2017/12/25 jQuery
微信小程序实现全局搜索代码高亮的示例
2018/03/30 Javascript
微信小程序如何访问公众号文章
2019/07/08 Javascript
JS实现星星海特效
2019/12/24 Javascript
vue项目中使用vue-layer弹框插件的方法
2020/03/11 Javascript
JS实现点星星消除小游戏
2020/03/24 Javascript
原理深度解析Vue的响应式更新比React快
2020/04/04 Javascript
[52:03]DOTA2-DPC中国联赛 正赛 Ehome vs iG BO3 第三场 1月31日
2021/03/11 DOTA
python中定义结构体的方法
2013/03/04 Python
解决PyCharm中光标变粗的问题
2017/08/05 Python
对变量赋值的理解--Pyton中让两个值互换的实现方法
2017/11/29 Python
Python2中文处理纪要的实现方法
2018/03/10 Python
python cumsum函数的具体使用
2019/07/29 Python
Python Pandas 如何shuffle(打乱)数据
2019/07/30 Python
浅谈tensorflow之内存暴涨问题
2020/02/05 Python
Python爬虫之Selenium多窗口切换的实现
2020/12/04 Python
CSS3实现超慢速移动动画效果非常流畅无卡顿
2014/06/15 HTML / CSS
纽约的奢华内衣店:Journelle
2016/07/29 全球购物
Proenza Schouler官方网站:纽约女装和配饰品牌
2019/01/03 全球购物
售后服务经理岗位职责
2014/02/25 职场文书
法制宣传口号
2014/06/16 职场文书
机电专业毕业生求职信
2014/07/01 职场文书
和谐家庭事迹材料
2014/12/20 职场文书