91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-05-12 13:39:35 來源:億速云 閱讀:269 作者:小新 欄目:web開發

小編給大家分享一下如何利用canvas實現圖片下載功能來實現瀏覽器兼容問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

前言:項目中需要實現圖片下載功能,第一個想到的是使用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上無效;

以上是“如何利用canvas實現圖片下載功能來實現瀏覽器兼容問題”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宜丰县| 郎溪县| 定兴县| 盘山县| 利辛县| 沭阳县| 红桥区| 隆安县| 莱阳市| 酉阳| 巩义市| 罗城| 玉环县| 天等县| 兴宁市| 柞水县| 陈巴尔虎旗| 富平县| 汝阳县| 洛阳市| 北海市| 驻马店市| 四川省| 扶风县| 竹北市| 砚山县| 依兰县| 德清县| 家居| 奎屯市| 得荣县| 神农架林区| 鲜城| 两当县| 南召县| 萍乡市| 武陟县| 攀枝花市| 眉山市| 邻水| 昌宁县|