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在一段文字中的光标处插入其他文字
Aug 26 Javascript
从数组中随机取x条不重复数据的JS代码
Dec 24 Javascript
通过jquery 获取URL参数并进行转码
Aug 18 Javascript
jQuery简单实现验证邮箱格式
Jul 15 Javascript
jQuery实现仿微软首页感应鼠标变化滑动窗口效果
Oct 08 Javascript
浅析Bootstrap表格的使用
Jun 23 Javascript
基于js中的原型、继承的一些想法
Aug 10 Javascript
利用angularjs1.4制作的简易滑动门效果
Feb 28 Javascript
node.js中实现kindEditor图片上传功能的方法教程
Apr 26 Javascript
webstorm中vue语法的支持详解
May 09 Javascript
Node.js实现简单管理系统
Sep 23 Javascript
JavaScript复制变量三种方法实例详解
Jan 09 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/02/28 PHP
CI使用Tank Auth转移数据库导致密码用户错误的解决办法
2014/06/12 PHP
基于PHP的简单采集数据入库程序
2014/07/30 PHP
9个经典的PHP代码片段分享
2014/12/18 PHP
php使用iconv中文截断问题的解决方法
2015/02/11 PHP
PHP基于自定义函数实现的汉字转拼音功能实例
2017/09/30 PHP
jquery入门必备的基本认识及实例(整理)
2013/06/24 Javascript
javascript根据像素点取位置示例
2014/01/27 Javascript
jQuery中extend函数详解
2015/02/13 Javascript
nodejs实现获取某宝商品分类
2015/05/28 NodeJs
jquery动态导航插件dynamicNav用法实例分析
2015/09/06 Javascript
纯javascript移动优先的幻灯片效果
2015/11/02 Javascript
JS Array.slice 截取数组的实现方法
2016/01/02 Javascript
利用原生js和jQuery实现单选框的勾选和取消操作的方法
2016/09/04 Javascript
jQuery实现可展开折叠的导航效果示例
2016/09/12 Javascript
AngularJS过滤器filter用法分析
2016/12/11 Javascript
深入探究angular2 UI组件之primeNG用法
2017/07/26 Javascript
jQuery上传插件webupload使用方法
2017/08/01 jQuery
Vue 源码分析之 Observer实现过程
2018/03/29 Javascript
Angular4 反向代理Details实践
2018/05/30 Javascript
vue-cli3添加模式配置多环境变量的方法
2019/06/05 Javascript
Vue+Element实现网页版个人简历系统(推荐)
2019/12/31 Javascript
基于VSCode调试网页JavaScript代码过程详解
2020/07/20 Javascript
Python 元类使用说明
2009/12/18 Python
Python数据结构与算法之图的基本实现及迭代器实例详解
2017/12/12 Python
为什么入门大数据选择Python而不是Java?
2018/03/07 Python
分析python请求数据
2018/08/19 Python
Python爬虫图片懒加载技术 selenium和PhantomJS解析
2019/09/18 Python
pyhton中__pycache__文件夹的产生与作用详解
2019/11/24 Python
selenium+python实现自动登陆QQ邮箱并发送邮件功能
2019/12/13 Python
Python Pandas list列表数据列拆分成多行的方法实现
2020/12/14 Python
简单介绍Object类的功能、常用方法
2013/10/02 面试题
电视购物广告词
2014/03/19 职场文书
施工协议书范本
2014/04/22 职场文书
2014年学生会部门工作总结
2014/11/07 职场文书
人事任命书范本
2015/09/21 职场文书