国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

利用canvas實現(xiàn)圖片下載功能來實現(xiàn)瀏覽器兼容問題

2024-08-26 00:21:30
字體:
供稿:網(wǎng)友

前言:項目中需要實現(xiàn)圖片下載功能,第一個想到的是使用a標簽的download屬性來實現(xiàn),但是在不同瀏覽器下測試會發(fā)現(xiàn),有的瀏覽器無效,點擊后直接預覽圖片,所以,上網(wǎng)找到了另外一種兼容不同瀏覽器的圖片下載的方法,那就是利用canvas來處理圖片,實現(xiàn)下載;

1.項目中點擊事件綁定:

<a href="#" @click.prevent="downloadIamge(imgsrc, name)"><span>{{name}}</span></a>

2.點擊事件中操作:

downloadIamge (imgsrc, name) {      const url = imgsrc      this.convertUrlToBase64(url).then((base64) => {        const blob = this.convertBase64UrlToBlob(base64)        if (getBrowser() === 'IE' || getBrowser() === 'Edge') {          window.navigator.msSaveBlob(blob, name)        } else {          const a = document.createElement('a')          const body = document.querySelector('body')          a.download = name || 'image'          a.href = URL.createObjectURL(blob)          a.style.display = 'none'          body.appendChild(a)          a.click()          body.removeChild(a)          window.URL.revokeObjectURL(a.href)        }      })    },

3.this.convertUrlToBase64(url)就是利用canvas和toDataURL把圖片轉(zhuǎn)成base64格式并返回

convertUrlToBase64 (url) {      return new Promise((resolve, reject) => {        const img = new Image()        img.crossOrigin = 'Anonymous'        img.src = url        img.onload = function () {          const canvas = document.createElement('canvas')          canvas.width = img.width          canvas.height = img.height          const ctx = canvas.getContext('2d')          ctx.drawImage(img, 0, 0, img.width, img.height)          const ext = img.src.substring(img.src.lastIndexOf('.') + 1).toLowerCase()          const dataURL = canvas.toDataURL('image/' + ext)          const base64 = {            dataURL: dataURL,            type: 'image/' + ext,            ext: ext          }          resolve(base64)        }      })    },

其中:img.crossOrigin = 'Anonymous'是前端對圖片的跨域處理;

4.this.convertBase64UrlToBlob(base64)是將圖片base64流文件轉(zhuǎn)成blob文件

convertBase64UrlToBlob (base64) {      const parts = base64.dataURL.split('base64,')      const contentType = parts[0].split(':')[1]      const raw = window.atob(parts[1])      const rawLength = raw.length      const uInt8Array = new Uint8Array(rawLength)      for (let i = 0; i < rawLength; i++) {        uInt8Array[i] = raw.charCodeAt(i)      }      return new Blob([uInt8Array], { type: contentType })    },

5.getBrowser()用來判斷瀏覽器,解決瀏覽器兼容性問題:

import { getBrowser } from '@/utils/utils'export function getBrowser () {  const userAgent = navigator.userAgent  if (userAgent.indexOf('OPR') > -1) {    return 'Opera'  }  if (userAgent.indexOf('Firefox') > -1) {    return 'FF'  }  if (userAgent.indexOf('Trident') > -1) {    return 'IE'  }  if (userAgent.indexOf('Edge') > -1) {    return 'Edge'  }  if (userAgent.indexOf('Chrome') > -1) {    return 'Chrome'  }  if (userAgent.indexOf('Safari') > -1) {    return 'Safari'  }}

6.如果是IE或者Edge瀏覽器,可以直接使用window.navigator.msSaveBlob(blob, name)完成下載;

聲明:由于ios系統(tǒng)有安全性限制,以上方法在ios上無效;

以上就是記錄項目中用到的圖片下載,瀏覽器兼容的問題,涉及到的base64和blob的知識點和原理還不是很清晰,有時間一定要研究一下,整個方法,親測有效;歡迎測用,與意見反饋。也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識閱讀請移步到HTML教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 沁水县| 建德市| 重庆市| 曲沃县| 广安市| 紫金县| 浏阳市| 绥芬河市| 麻城市| 婺源县| 彰武县| 德化县| 紫阳县| 淮滨县| 五原县| 巫山县| 承德市| 吉木萨尔县| 华宁县| 赤城县| 塘沽区| 靖宇县| 德格县| 玛纳斯县| 林西县| 榆树市| 临城县| 射洪县| 连江县| 望奎县| 高碑店市| 县级市| 正蓝旗| 德令哈市| 田林县| 东港市| 黄石市| 加查县| 贵德县| 肃宁县| 五指山市|