亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

利用canvas實現圖片下載功能來實現瀏覽器兼容問題

2024-08-26 00:21:30
字體:
來源:轉載
供稿:網友

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

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把圖片轉成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流文件轉成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系統有安全性限制,以上方法在ios上無效;

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区美女视频| 亚洲无限乱码一二三四麻| 91国产一区在线| 国产一区二区黑人欧美xxxx| 欧美尤物巨大精品爽| 2021久久精品国产99国产精品| 成人乱人伦精品视频在线观看| 久久久久久国产精品久久| 亚洲尤物视频网| 欧美亚洲国产成人精品| 亚洲欧美日韩在线高清直播| 国产精品久久久久久久久久东京| 亚洲欧美变态国产另类| 日韩亚洲综合在线| 91久久久久久国产精品| 亚洲福利视频专区| 91久久精品国产91性色| 国产精品久久久久久久久男| 精品久久久久久久久久| 日韩在线视频网站| 成人av番号网| 色悠悠国产精品| 亚洲bt欧美bt日本bt| 国产日产欧美精品| 国产精品一区二区久久精品| 欧美一级视频在线观看| 国产精品1234| 国产成人精品久久久| 色视频www在线播放国产成人| 国产精品亚洲аv天堂网| 亚洲人永久免费| 欧美理论电影网| 黑人狂躁日本妞一区二区三区| 欧美成人午夜激情| 亚洲自拍偷拍视频| 国产97在线亚洲| 亚洲成人精品视频| 欧美精品在线观看91| 亚洲女人被黑人巨大进入al| 97在线看免费观看视频在线观看| 国产美女91呻吟求| 欧美成人精品一区二区| 久久久亚洲天堂| 中文字幕成人精品久久不卡| 国产69精品99久久久久久宅男| 亚洲a中文字幕| 2021国产精品视频| 成人在线一区二区| 亚洲欧美中文日韩v在线观看| 2019国产精品自在线拍国产不卡| 韩剧1988免费观看全集| 欧美在线视频观看免费网站| 激情久久av一区av二区av三区| 97久久超碰福利国产精品…| 亚洲欧洲日产国产网站| 日韩第一页在线| 97在线观看视频国产| 久久久久久亚洲精品| 日韩美女写真福利在线观看| 一区二区三区日韩在线| 欧美男插女视频| 欧美日本中文字幕| 国产精品色悠悠| www.亚洲一二| 欧美激情影音先锋| 日韩av大片在线| 欧美亚洲视频在线看网址| 欧美日韩亚洲成人| 国产亚洲欧美视频| 日韩第一页在线| 在线视频中文亚洲| 日韩电影大片中文字幕| 国产精品美女视频网站| 久久久久久久久国产精品| 亚洲欧洲在线免费| 91久久精品在线| 日韩av影视在线| 成人有码在线播放| 国内外成人免费激情在线视频网站| 久久精品视频播放| 欧美在线性爱视频| 欧美午夜宅男影院在线观看| 成人欧美在线视频| **欧美日韩vr在线| 亚洲免费电影在线观看| 九色91av视频| 精品呦交小u女在线| 午夜精品福利电影| 538国产精品一区二区在线| 久久综合久中文字幕青草| 久久精品视频在线播放| 色99之美女主播在线视频| 日韩成人av网| 久久成年人免费电影| 久久天天躁夜夜躁狠狠躁2022| 91深夜福利视频| 久久国产视频网站| 午夜精品久久久久久久久久久久| 国产日韩av在线播放| 欧美日韩国产综合新一区| 国产视频精品自拍| 97视频人免费观看| 亲爱的老师9免费观看全集电视剧| 亚洲自拍偷拍区| 国产69久久精品成人| 国语自产精品视频在线看一大j8| 成人激情av在线| 久久免费视频在线| 日韩在线精品视频| 亚洲欧美日韩天堂一区二区| 久久久精品久久久久| 热久久99这里有精品| 97久久伊人激情网| 91大神在线播放精品| 日韩欧美在线免费观看| 欧美日韩一区二区三区在线免费观看| 精品久久久久久中文字幕| 日韩激情视频在线播放| 欧洲日本亚洲国产区| 97超碰蝌蚪网人人做人人爽| 日韩欧美中文字幕在线播放| 欧美日韩国产一区二区三区| 国产日韩中文字幕| 亚洲精品日韩av| 美女av一区二区三区| 国产精品久久久久福利| 精品国产区一区二区三区在线观看| 欧美午夜精品久久久久久浪潮| 久久精品在线播放| 亚洲精品国精品久久99热一| 亚洲欧美中文另类| 欧美激情第一页xxx| 日韩中文字幕在线播放| 日韩欧美在线中文字幕| 日韩在线欧美在线国产在线| 亚洲国产天堂久久国产91| 欧美色videos| 九九热这里只有精品6| 91欧美视频网站| 久久精品亚洲一区| 精品久久久久久久久久ntr影视| 久久久久久久久久久久久久久久久久av| 精品国产欧美成人夜夜嗨| 精品香蕉在线观看视频一| 欧美老女人www| 久久亚洲电影天堂| 亚洲天堂日韩电影| 亚洲国产毛片完整版| 亚洲乱亚洲乱妇无码| 久久精品视频中文字幕| 国产玖玖精品视频| 成人免费淫片aa视频免费| 亚洲欧美三级在线| 久久av中文字幕| 亚洲最新中文字幕| 欧美精品videossex88| 欧美激情精品久久久久久| 日韩欧美第一页| 欧美在线视频免费播放| 亚洲精品aⅴ中文字幕乱码| 国产999精品视频| 亚洲免费成人av电影| 性欧美长视频免费观看不卡| 久久伊人精品一区二区三区|