加入收藏 | 设为首页 | 会员中心 | 我要投稿 河北网 (https://www.hebeiwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

操作canvas实现图片下载成果来实现赏识器兼容题目

发布时间:2020-03-29 21:50:22 所属栏目:编程 来源:站长网
导读:媒介:项目中必要实现图片下载成果,第一个想到的是行使a标签的download属性来实现,可是在差异赏识器下测试会发明,有的赏识器无效,点击后直接预览图片,以是,上网找到了其它一种兼容差异赏识器的图片下载的要领,那就是操作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上无效;

以上就是记录项目顶用到的图片下载,赏识器兼容的题目,涉及到的base64和blob的常识点和道理还不是很清楚,偶然刻必然要研究一下,整个要领,亲测有用;接待测用,与意见反馈。也但愿各人多多支持剧本之家。

(编辑:河北网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读