欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

[點晴永久免費OA]【JavaScript】JS壓縮圖片

admin
2023年5月6日 12:40 本文熱度 1077

上傳圖片時候,遇到要上傳很大的圖片,上傳的時候就會很慢。所以,需要對圖片進行壓縮處理來優化上傳功能。

圖片壓縮函數:

/* 
 * 圖片壓縮
 * img    原始圖片
 * width   壓縮后的寬度
 * height  壓縮后的高度
 * ratio   壓縮比率 
 */
 function compress(img, width, height, ratio) {        
   var canvas, ctx, img64;
        
   canvas = document.createElement('canvas');        
   canvas.width = width;
   canvas.height = height;
        
   ctx = canvas.getContext("2d");        
   ctx.drawImage(img, 0, 0, width, height);
        
   img64 = canvas.toDataURL("image/jpeg", ratio);
        
   return img64;
 }123456789101112131415161718192021

圖片壓縮函數,返回 base64 格式的圖片數據。 其中壓縮比率ratio取值(0 - 1 之間),ratio越大圖片質量越高。

這里將圖片轉為 jpeg格式,因為轉為 png 格式的話,圖片的 base64 比轉為 jpeg 的要長不少。

<input type="file" accept="image/*" name="imageFile" @change="upload">1

上傳圖片后 @change綁定的upload 函數將被觸發,在這個函數中獲取到圖片的資源,將它壓縮并利用canvas繪制出來。

  upload () {
   let file = document.queryselector('input[type=file]').files[0] // 獲取選擇的文件,這里是圖片類型
   let reader = new FileReader()
   reader.readAsDataURL(file) //讀取文件并將文件以URL的形式保存在resulr屬性中 base64格式
   reader.onload = (e) => { // 文件讀取完成時觸發
    let result = e.target.result // base64格式圖片地址
    var image = new Image()
    image.src = result // 設置image的地址為base64的地址
    image.onload = () => { // 圖片加載完成后才能進行壓縮處理,從而轉換為base64 進行賦值
    let width = image.width // 圖片寬度
    let height = image.height    let dataUrl = this.compress(image, width, height, 0.7)
    document.getElementById("test").src = dataUrl   }
   }
  }12345678910111213141516

壓縮圖片結果對比:
大小對比:
在這里插入圖片描述
分辨率對比:
在這里插入圖片描述
壓縮2M的圖片:

大小對比:
在這里插入圖片描述

分辨率對比:
在這里插入圖片描述

demo完整版代碼:

<template>
  <div>
  <input type="file" accept="image/*" name="imageFile" @change="upload">
    <img id="test" crossorigin alt="">
 </div></template><script>export default {
 name: '',
 data () {
  return {
  }
 },
 components: {
 },
 created () {
 },
 methods: {
  upload () {
   let file = document.queryselector('input[type=file]').files[0] // 獲取選擇的文件,這里是圖片類型
   let reader = new FileReader()
   reader.readAsDataURL(file) //讀取文件并將文件以URL的形式保存在resulr屬性中 base64格式
   reader.onload = (e) => { // 文件讀取完成時觸發
    let result = e.target.result // base64格式圖片地址
    var image = new Image()
    image.src = result // 設置image的地址為base64的地址
    image.onload = () => { // 圖片加載完成后才能進行壓縮處理,從而轉換為base64 進行賦值
    let width = image.width // 圖片寬度
    let height = image.height    let dataUrl = this.compress(image, width, height, 0.7)
    document.getElementById("test").src = dataUrl   }
   }
  },
  /*
   * 圖片壓縮
   * img   原始圖片
   * width  壓縮后的寬度
   * height  壓縮后的高度
   * ratio  壓縮比率
  */
  compress (img, width, height, ratio) {
   let canvas, ctx, img64;
   canvas = document.createElement('canvas')
   canvas.width = width;
   canvas.height = height;
   ctx = canvas.getContext("2d");
   ctx.drawImage(img, 0, 0, width, height);
   img64 = canvas.toDataURL("image/jpeg", ratio);
   return img64;
  }
 }}</script><style lang="less" scoped></style>

該文章在 2023/5/6 12:40:23 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved