圖片壓縮上傳

一、根據input獲取用戶選取的圖片文件

let _file = this.$refs.input.files[0]web

二、將_file文件流經過FileReader轉化成base64

/**
 * 文件流轉base64
 * @param {file} source 圖片對象
 * @param {number} quality 圖片質量
 * @return {promise} promise 圖片處理promise
 */
export const fileToBase64ByQuality = (file, quality) => {
  let fileReader = new FileReader()
  let type = file.type
  return new Promise((resolve, reject) => {
    if (window.URL || window.webkitURL) {
      resolve(compress(URL.createObjectURL(file), quality, type))
    } else {
      fileReader.onload = () => {
        resolve(compress(fileReader.result, quality, type))
      }
      fileReader.onerror = (e) => {
        reject(e)
      }
      fileReader.readAsDataURL(file)
    }
  })
}複製代碼

三、處理base64數據經過canvas(toDataURL)進行壓縮繪製,而後輸出壓縮後的base64圖片數據

//  圖片最大寬度
const MAX_WIDTH = 800

/**
 * base64壓縮(圖片-canvas互轉)
 * @param {file} base64 base64圖片數據
 * @param {number} quality 圖片質量
 * @param {string} format 輸出圖片格式
 * @return {base64} data 圖片處理完成後的base64
 */
export const compress = (base64, quality, mimeType) => {
  let cvs = document.createElement('canvas')
  let img = document.createElement('img')
  img.crossOrigin = 'anonymous'
  return new Promise((resolve, reject) => {
    img.src = base64
    // 圖片偏移值
    let offetX = 0
    img.onload = () => {
      if (img.width > MAX_WIDTH) {
        cvs.width = MAX_WIDTH
        cvs.height = img.height * MAX_WIDTH / img.width
        offetX = (img.width - MAX_WIDTH) / 2
      } else {
        cvs.width = img.width
        cvs.height = img.height
      }
      let ctx = cvs.getContext("2d").drawImage(img, 0, 0, cvs.width, cvs.height)
      let imageData = cvs.toDataURL(mimeType, quality / 100)
      resolve(imageData)
    }
  })
}複製代碼

四、最後base64數據轉成blob文件流

/**
 * base64轉文件流
 * @param {base64} base64數據 
 * @param {string} format格式
 * @return {file}  文件blob
 */
export const convertBase64UrlToBlob = (base64, mimeType) => {
  let bytes = window.atob(base64.split(',')[1])
  let ab = new ArrayBuffer(bytes.length)
  let ia = new Uint8Array(ab)
  for (let i = 0; i < bytes.length; i++) {
    ia[i] = bytes.charCodeAt(i)
  }
  let _blob = new Blob([ab], { type: mimeType })
  return _blob
}複製代碼

五、構造FormData數據進行文件的上傳

let formData = new window.FormData()
formData.append('file', _blob)複製代碼

相關文章
相關標籤/搜索