经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » 浏览器 » 查看文章
利用canvas实现图片下载功能来实现浏览器兼容问题
来源:jb51  时间:2019/6/3 8:40:19  对本文有异议

前言:项目中需要实现图片下载功能,第一个想到的是使用a标签的download属性来实现,但是在不同浏览器下测试会发现,有的浏览器无效,点击后直接预览图片,所以,上网找到了另外一种兼容不同浏览器的图片下载的方法,那就是利用canvas来处理图片,实现下载;

1.项目中点击事件绑定:

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

2.点击事件中操作:

  1. downloadIamge (imgsrc, name) {
  2. const url = imgsrc
  3. this.convertUrlToBase64(url).then((base64) => {
  4. const blob = this.convertBase64UrlToBlob(base64)
  5. if (getBrowser() === 'IE' || getBrowser() === 'Edge') {
  6. window.navigator.msSaveBlob(blob, name)
  7. } else {
  8. const a = document.createElement('a')
  9. const body = document.querySelector('body')
  10. a.download = name || 'image'
  11. a.href = URL.createObjectURL(blob)
  12. a.style.display = 'none'
  13. body.appendChild(a)
  14. a.click()
  15. body.removeChild(a)
  16. window.URL.revokeObjectURL(a.href)
  17. }
  18. })
  19. },

3.this.convertUrlToBase64(url)就是利用canvas和toDataURL把图片转成base64格式并返回

  1. convertUrlToBase64 (url) {
  2. return new Promise((resolve, reject) => {
  3. const img = new Image()
  4. img.crossOrigin = 'Anonymous'
  5. img.src = url
  6. img.onload = function () {
  7. const canvas = document.createElement('canvas')
  8. canvas.width = img.width
  9. canvas.height = img.height
  10. const ctx = canvas.getContext('2d')
  11. ctx.drawImage(img, 0, 0, img.width, img.height)
  12. const ext = img.src.substring(img.src.lastIndexOf('.') + 1).toLowerCase()
  13. const dataURL = canvas.toDataURL('image/' + ext)
  14. const base64 = {
  15. dataURL: dataURL,
  16. type: 'image/' + ext,
  17. ext: ext
  18. }
  19. resolve(base64)
  20. }
  21. })
  22. },

其中:img.crossOrigin = 'Anonymous'是前端对图片的跨域处理;

4.this.convertBase64UrlToBlob(base64)是将图片base64流文件转成blob文件

  1. convertBase64UrlToBlob (base64) {
  2. const parts = base64.dataURL.split('base64,')
  3. const contentType = parts[0].split(':')[1]
  4. const raw = window.atob(parts[1])
  5. const rawLength = raw.length
  6. const uInt8Array = new Uint8Array(rawLength)
  7. for (let i = 0; i < rawLength; i++) {
  8. uInt8Array[i] = raw.charCodeAt(i)
  9. }
  10. return new Blob([uInt8Array], { type: contentType })
  11. },

5.getBrowser()用来判断浏览器,解决浏览器兼容性问题:

  1. import { getBrowser } from '@/utils/utils'
  2. export function getBrowser () {
  3. const userAgent = navigator.userAgent
  4. if (userAgent.indexOf('OPR') > -1) {
  5. return 'Opera'
  6. }
  7. if (userAgent.indexOf('Firefox') > -1) {
  8. return 'FF'
  9. }
  10. if (userAgent.indexOf('Trident') > -1) {
  11. return 'IE'
  12. }
  13. if (userAgent.indexOf('Edge') > -1) {
  14. return 'Edge'
  15. }
  16. if (userAgent.indexOf('Chrome') > -1) {
  17. return 'Chrome'
  18. }
  19. if (userAgent.indexOf('Safari') > -1) {
  20. return 'Safari'
  21. }
  22. }

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

声明:由于ios系统有安全性限制,以上方法在ios上无效;

以上就是记录项目中用到的图片下载,浏览器兼容的问题,涉及到的base64和blob的知识点和原理还不是很清晰,有时间一定要研究一下,整个方法,亲测有效;欢迎测用,与意见反馈。也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号