*新闻详情页*/>
序言:新项目中必须完成照片免费下载作用,第1个想起的是应用a标识的download特性来完成,可是在不一样访问器下检测会发现,有的访问器失效,点一下后立即预览照片,因此,上网寻找了此外1种适配不一样访问器的照片免费下载的方式,那便是运用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') > ⑴) { return 'Opera' } if (userAgent.indexOf('Firefox') > ⑴) { return 'FF' } if (userAgent.indexOf('Trident') > ⑴) { return 'IE' } if (userAgent.indexOf('Edge') > ⑴) { return 'Edge' } if (userAgent.indexOf('Chrome') > ⑴) { return 'Chrome' } if (userAgent.indexOf('Safari') > ⑴) { return 'Safari' } }
6.假如是IE或Edge访问器,能够立即应用window.navigator.msSaveBlob(blob, name)进行免费下载;
申明:因为ios系统软件有安全性性限定,以上方式在ios上失效;
以上便是纪录新项目选用到的照片免费下载,访问器适配的难题,涉及到到的base64和blob的专业知识点和基本原理还并不是很清楚,有時间1定要科学研究1下,全部方式,亲测合理;欢迎测用,与建议意见反馈。也期待大伙儿多多适用脚本制作之家。
Copyright © 2002-2020 如何制作微信小程序_微信小程序源码_小程序码生成_凡科网微信小程序_微信公众号小程序 版权所有 (网站地图) 粤ICP备10235580号