狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

[點(diǎn)晴永久免費(fèi)OA]【JavaScript】JS壓縮圖片

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

上傳圖片時(shí)候,遇到要上傳很大的圖片,上傳的時(shí)候就會(huì)很慢。所以,需要對(duì)圖片進(jìn)行壓縮處理來優(yōu)化上傳功能。

圖片壓縮函數(shù):

/* 
 * 圖片壓縮
 * 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

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

這里將圖片轉(zhuǎn)為 jpeg格式,因?yàn)檗D(zhuǎn)為 png 格式的話,圖片的 base64 比轉(zhuǎn)為 jpeg 的要長不少。

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

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

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

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

大小對(duì)比:
在這里插入圖片描述

分辨率對(duì)比:
在這里插入圖片描述

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) => { // 文件讀取完成時(shí)觸發(fā)
    let result = e.target.result // base64格式圖片地址
    var image = new Image()
    image.src = result // 設(shè)置image的地址為base64的地址
    image.onload = () => { // 圖片加載完成后才能進(jìn)行壓縮處理,從而轉(zhuǎn)換為base64 進(jìn)行賦值
    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 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved