欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript圖片url地址轉(zhuǎn)base64簡單示例

 更新時間:2023年10月27日 10:47:57   作者:vanora1111  
這篇文章主要給大家介紹了關(guān)于JavaScript圖片url地址轉(zhuǎn)base64的相關(guān)資料,圖片URL轉(zhuǎn)Base64是把圖片URL轉(zhuǎn)化為一個以base64編碼的字符串格式,使得圖片可以直接在HTML或CSS中使用,需要的朋友可以參考下

前言

記錄來自于每一次的實(shí)際需求;

此次需要做的是將拿到的圖片,轉(zhuǎn)png格式下載,看了下數(shù)據(jù)庫返回的地址,有png、svg、jpg格式,我的想法是先通通轉(zhuǎn)base64,再處理成png下載。

一、圖片地址轉(zhuǎn)base64

1、先定義一個方法 

/**
 * 根據(jù)圖片的url轉(zhuǎn)換對應(yīng)的base64值
 * @param { String } imageUrl 如:http://xxxx/xxx.png
 * @returns base64取值
 */
async urlToBase64(imageUrl) {
    return new Promise((resolve, reject) => {
      let canvas = document.createElement('canvas')
      const ctx = canvas.getContext('2d')
      let img = new Image()
      img.crossOrigin = 'Anonymous' // 解決Canvas.toDataURL 圖片跨域問題
      img.src = imageUrl
      img.onload = function() {
        canvas.height = img.height
        canvas.width = img.width
        ctx.fillStyle = '#fff' // canvas背景填充顏色默認(rèn)為黑色
        ctx.fillRect(0,0,img.width,img.height)
        ctx.drawImage(img, 0, 0) // 參數(shù)可自定義
        const dataURL = canvas.toDataURL('image/jpeg', 1) // 獲取Base64編碼
        resolve(dataURL)
        canvas = null // 清除canvas元素
        img = null // 清除img元素
      }
      img.onerror = function() {
        reject(new Error('Could not load image at ' + imageUrl))
      }
    })
}

2、存儲返回的base64,并轉(zhuǎn)為png格式下載

/**
* 下載圖片的方法
 * @param { String } imageUrl 如:http://xxxx/xxx.png
 * @returns base64取值
 */
async upload(item) {
 // 此處的src 是圖片地址,如: http://xxxx/xxx.png 
  let { src, name } = item
  // 存儲base64的值
  let base64 = await this.urlToBase64(src)
  let link = document.createElement('a')
  link.href = base64
  link.download = `${name}.png`
  link.click()
}

補(bǔ)充知識:

1)將base64圖片格式轉(zhuǎn)為可讀的url格式

將圖片文件轉(zhuǎn)為二進(jìn)制,然后通過URL的createObjectURL函數(shù),將二進(jìn)制轉(zhuǎn)為url格式

   function getBase64URL(pic) {
        const blob = base64ImgtoFile(pic)
        const blobUrl = window.URL.createObjectURL(blob);
        return blobUrl
    }

2)將圖片轉(zhuǎn)為文件

function base64ImgtoFile (dataurl, filename = 'file') {
        //將base64格式分割:['data:image/png;base64','XXXX']
        const arr = dataurl.split(',')
        // .*? 表示匹配任意字符到下一個符合條件的字符 剛好匹配到:
        // image/png
        const mime = arr[0].match(/:(.*?);/)[1]  //image/png
        //[image,png] 獲取圖片類型后綴
        const suffix = mime.split('/')[1] //png
        const bstr = atob(arr[1])   //atob() 方法用于解碼使用 base-64 編碼的字符串
        let n = bstr.length
        const u8arr = new Uint8Array(n)
        while (n--) {
            u8arr[n] = bstr.charCodeAt(n)
        }
        return new File([u8arr], `${filename}.${suffix}`, {
            type: mime
        })
    }

總結(jié) 

到此這篇關(guān)于JavaScript圖片url地址轉(zhuǎn)base64的文章就介紹到這了,更多相關(guān)JS圖片url地址轉(zhuǎn)base64內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • layui擴(kuò)展上傳組件模擬進(jìn)度條的方法

    layui擴(kuò)展上傳組件模擬進(jìn)度條的方法

    今天小編就為大家分享一篇 layui擴(kuò)展上傳組件模擬進(jìn)度條的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 最新評論