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的AutoComplete插件
May 04 Javascript
js时间日期格式化封装函数
Dec 02 Javascript
javascript实现复选框超过限制即弹出警告框的方法
Feb 25 Javascript
JavaScript检查弹出窗口是否被阻拦的方法技巧
Mar 13 Javascript
JS实现的Select三级下拉菜单代码
Aug 20 Javascript
JavaScript简单遍历DOM对象所有属性的实现方法
Oct 21 Javascript
Vue.js学习之计算属性
Jan 22 Javascript
Bootstrap模态框插入视频的实现代码
Jun 25 Javascript
jQuery实现列表的增加和删除功能
Jun 14 jQuery
vue实现标签云效果的方法详解
Aug 28 Javascript
前端深入理解Typescript泛型概念
Mar 09 Javascript
解决Nuxt使用axios跨域问题
Jul 06 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 Socket写的POP3类
2013/10/30 PHP
详解Yii2 定制表单输入字段的标签和样式
2017/01/04 PHP
php制作圆形用户头像的实例_自定义封装类源代码
2017/09/18 PHP
PHP实现对数字分隔加千分号的方法
2019/03/18 PHP
jQuery Tools tab(幻灯片)
2012/07/14 Javascript
js点击选择文本的方法
2015/02/09 Javascript
js数组如何添加json数据及js数组与json的区别
2015/10/27 Javascript
js立即执行函数: (function ( ){})( ) 与 (function ( ){}( )) 有什么区别?
2015/11/18 Javascript
bootstrap快速制作后台界面
2016/12/05 Javascript
BootStrap学习系列之布局组件(下拉,按钮组[toolbar],上拉)
2017/01/03 Javascript
MUI  Scroll插件的使用详解
2017/04/13 Javascript
打字效果动画的4种实现方法(超简单)
2017/10/18 Javascript
Vue仿支付宝支付功能
2018/05/25 Javascript
vue自定义底部导航栏Tabbar的实现代码
2018/09/03 Javascript
Element Input组件分析小结
2018/10/11 Javascript
Vue仿微信app页面跳转动画效果
2019/08/21 Javascript
layer.open 获取不到表单信息的解决方法
2019/09/26 Javascript
jQuery操作选中select下拉框的值代码实例
2020/02/07 jQuery
[01:04:05]VG vs Newbee 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
Python RuntimeError: thread.__init__() not called解决方法
2015/04/28 Python
python读取tif图片时保留其16bit的编码格式实例
2020/01/13 Python
Python 中由 yield 实现异步操作
2020/05/04 Python
python的help函数如何使用
2020/06/11 Python
python 检测图片是否有马赛克
2020/12/01 Python
用CSS3的box-reflect来制作倒影效果
2016/11/15 HTML / CSS
Css3新特性应用之视觉效果实例
2016/12/12 HTML / CSS
伦敦剧院及景点门票:Encore Tickets
2018/07/01 全球购物
施华洛世奇意大利官网:SWAROVSKI意大利
2018/07/23 全球购物
对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中
2015/06/22 面试题
创业计划书的主要内容有哪些
2014/01/29 职场文书
横幅标语大全
2014/06/17 职场文书
2014入党积极分子批评与自我批评思想汇报
2014/09/20 职场文书
幼儿体育课教学反思
2016/02/16 职场文书
goland 清除所有的默认设置操作
2021/04/28 Golang
Python torch.flatten()函数案例详解
2021/08/30 Python
国庆节到了,利用JS实现一个生成国庆风头像的小工具 详解实现过程
2021/10/05 Javascript