首頁  >  文章  >  web前端  >  在js中如何實現上傳並壓縮圖片功能(詳細教學)

在js中如何實現上傳並壓縮圖片功能(詳細教學)

亚连
亚连原創
2018-06-12 16:36:032714瀏覽

這篇文章主要為大家詳細介紹了js實作上傳並壓縮圖片的相關程式碼,具有一定的參考價值,有興趣的小夥伴們可以參考一下

#本文實例為大家分享了js實作上傳並圖片壓縮的具體程式碼,供大家參考,具體內容如下

程式碼:

<!DOCTYPE html>
<html>
 <head>
  <meta charset="UTF-8">
  <title></title>
  <script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
 </head>
 <body>
  <input type="file" id="picFile" onchange="readFile(this)"/> 
  <img style="" id="img" src="" alt="" />
  <script>
  function readFile(obj){ 
   var file = obj.files[0];  
   //判断类型是不是图片 
    if(!/image\/\w+/.test(file.type)){ 
      alert("请确保文件为图像类型"); 
      return false; 
    } 
    var reader = new FileReader(); 
    reader.readAsDataURL(file); 
    reader.onload = function(e){
     dealImage(this.result,{width:200},function(base){
         document.getElementById(&#39;img&#39;).setAttribute(&#39;src&#39;,base)
     });
    } 
  } 
 
  /**
   * 图片压缩,默认同比例压缩
   * @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(&#39;canvas&#39;);
   var ctx = canvas.getContext(&#39;2d&#39;);
   // 创建属性节点
   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);
   }
  }
  </script>
 </body>
</html>

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

如何建立element-ui(詳細教學)

在Vue2模板中如何使用template

在Vue中如何建立元件

在Vue-cli中使用Eslint如何實作自動格式化

在ES6中子元件呼叫父元件使用方法

在angular中如何製作動態表單

在angularjs中使用$http實作非同步上傳Excel檔案方法

透過vuejs如何實作資料驅動視圖原則

#

以上是在js中如何實現上傳並壓縮圖片功能(詳細教學)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn