首页 web前端 js教程 javascript实现图片压缩的代码

javascript实现图片压缩的代码

Aug 22, 2018 am 11:27 AM
图片压缩

本篇文章给大家带来的内容是关于javascript实现图片压缩的代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

废话不多说,直接上代码 返回的是一个base64的一个字符串

/**
 * 图片压缩,默认同比例压缩
 * @param {Object} path 
 *   pc端传入的路径可以为相对路径,但是在移动端上必须传入的路径是照相图片储存的绝对路径
 * @param {Object} obj
 *   obj 对象 有 width, height, quality(0-1)
 * @param {Object} callback
 *   回调函数有一个参数,base64的字符串数据
 */
function dealImage(path, obj, callback){
 var img = new Image();
 img.src = path;
 img.onload = function(){
  var that = this;
  // 默认按比例压缩
  var w = that.width,
   h = that.height,
   scale = w / h;
   w = obj.width || w;
   h = obj.height || (w / scale);
  var quality = 0.7;  // 默认图片质量为0.7
  //生成canvas
  var canvas = document.createElement('canvas');
  var ctx = canvas.getContext('2d');
  // 创建属性节点
  var anw = document.createAttribute("width");
  anw.nodeValue = w;
  var anh = document.createAttribute("height");
  anh.nodeValue = h;
  canvas.setAttributeNode(anw);
  canvas.setAttributeNode(anh); 
  ctx.drawImage(that, 0, 0, w, h);
  // 图像质量
  if(obj.quality && obj.quality <= 1 && obj.quality > 0){
   quality = obj.quality;
  }
  // quality值越小,所绘制出的图像越模糊
  var base64 = canvas.toDataURL(&#39;image/jpeg&#39;, quality );
  // 回调函数返回base64的值
  callback(base64);
 }
}
登录后复制

调用方法

// 调用函数处理图片                 
dealImage("路径", {
// 注意:在pc端可以用绝对路径或相对路径,移动端最好用绝对路径(因为用take photo后的图片路径,我没有试成功(如果有人试成功了可以分享一下经验))
 width : 200
}, function(base){
//直接将获取到的base64的字符串,放到一个image标签中就可看到测试后的压缩之后的样式图了
 document.getElementById("transform").src = base;
 console.log("压缩后:" + base.length / 1024 + " " + base);    
})
登录后复制

PS:主要思想就是获取到图片,利用H5 canvas技术进行图片数据化为 base64 的字符串,最后传到后台进行,后台将base64的字符串数据进行图像化储存。

相关推荐:

javascript实现省市联动的代码分享

javascript实现二叉树的代码介绍

以上是javascript实现图片压缩的代码的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

使用PHP保存远程图片时如何处理图片压缩? 使用PHP保存远程图片时如何处理图片压缩? Jul 15, 2023 pm 03:57 PM

使用PHP保存远程图片时如何处理图片压缩?在实际开发中,我们经常需要从网络上获取图片并保存到本地服务器。然而,有些远程图片可能太大,这就需要我们对它们进行压缩以减少存储空间和提高加载速度。PHP提供了一些功能强大的扩展来处理图片压缩,其中最常用的是GD库和Imagick库。GD库是一个流行的图像处理库,它提供了许多功能用于创建、编辑和保存图像。下面是一个使用

Vue技术开发中如何处理图片上传和压缩 Vue技术开发中如何处理图片上传和压缩 Oct 08, 2023 am 10:58 AM

Vue技术开发中如何处理图片上传和压缩在现代web应用中,图片上传是一个非常常见的需求。然而,由于网络传输和存储等方面的原因,直接上传原始的高分辨率图片可能会导致上传速度慢和存储空间的大量浪费。因此,对于图片的上传和压缩是非常重要的。在Vue技术开发中,我们可以使用一些现成的解决方案来处理图片上传和压缩。下面将介绍如何使用vue-upload-compone

uniapp中如何实现图片压缩功能 uniapp中如何实现图片压缩功能 Jul 06, 2023 pm 05:16 PM

uniapp中如何实现图片压缩功能一、引言在现代社会中,图片已经成为人们日常生活中不可或缺的一部分。然而,随着手机拍照功能的普及和照片像素的提升,图片的文件大小也不断增长。这不仅会占据手机内存,还会导致图片在网络传输过程中的加载时间过长。因此,对图片进行压缩已成为开发者重要的任务之一。二、uniapp中的图片压缩uniapp是基于Vue.js的跨平台开发框架

Java开发技巧揭秘:实现图片压缩与裁剪功能 Java开发技巧揭秘:实现图片压缩与裁剪功能 Nov 20, 2023 pm 03:27 PM

Java作为一种广泛应用于软件开发领域的编程语言,其丰富的库和强大的功能可用于开发各种应用程序。在Web和移动应用开发中,图片压缩和裁剪是常见的需求。在本文中,将揭秘一些Java开发技巧,帮助开发者实现图片压缩和裁剪的功能。首先,让我们讨论图片压缩的实现。在Web应用中,经常需要通过网络传输图片。如果图片过大,将会导致加载时间过长和占用更多的带宽。因此,我们

利用uniapp实现图片压缩功能 利用uniapp实现图片压缩功能 Nov 21, 2023 pm 06:36 PM

利用uniapp实现图片压缩功能随着手机拍照功能的提升,我们在日常生活中经常会拍摄大量的照片。然而,这些高像素的照片占据了手机的存储空间,使手机变得缓慢且容易存满。为了解决这个问题,我们可以利用uniapp中的相关技术,实现图片压缩功能,将图片压缩至更小的文件大小,保留合适的像素和画质。下面我们将详细介绍在uniapp中如何实现图片压缩功能。步骤一:引入相关

Vue技术开发中如何处理图片资源的压缩和优化 Vue技术开发中如何处理图片资源的压缩和优化 Oct 09, 2023 pm 08:27 PM

Vue技术开发中如何处理图片资源的压缩和优化摘要:随着前端开发的不断发展,网页中的图片占据越来越重要的位置。然而,图片资源过大会导致页面加载速度慢,影响用户体验。为了解决这个问题,本文将介绍如何使用Vue开发中处理图片资源的压缩和优化方法,并给出具体的代码示例。一、图片压缩手动压缩手动压缩是最常见的一种方式,可以使用各种图片处理软件,如Photoshop、S

怎么利用Node进行图片压缩 怎么利用Node进行图片压缩 Mar 20, 2023 pm 06:22 PM

怎么利用Node进行图片压缩?下面本篇文章以PNG图片为例给大家介绍一下进行图片压缩的方法,希望对大家有所帮助!

PHP开发中如何优化图片压缩和优化加载 PHP开发中如何优化图片压缩和优化加载 Oct 08, 2023 pm 06:18 PM

PHP开发中如何优化图片压缩和优化加载摘要:在网站中,图片是让用户获得更直观和有吸引力的体验的重要元素。然而,图片文件通常较大,加载速度较慢,会影响网站的性能和用户的体验。本文将详细介绍如何使用PHP开发来优化图片压缩和优化加载的方法,并提供具体的代码示例。请注意:本文所使用的代码需要配合服务器环境和扩展模块的配置使用,具体操作步骤和配置方法请根据自己的实际

See all articles