个别的下载,也就a标签加个链接地址,标签内加个download属性. 当地址是后端提供时:可通过创立a标签, 随即给a便签附下载链接,文件名和属性, 最初再创立点击成果,最初分明生成的a标签. 再则是图片地址提供:能够通过Base64加canvas,对图片的下载能够进行解决. 上面就是相干办法处理函数 HTML与文件下载
HTML与文件下载
<a href="large.jpg" download>下载</a>
文件下载配合后端表格导出
export function downloadFile(url, filename) {
// 创立暗藏的可下载链接
let link = document.createElement('a');
link.href = url;
link.download = filename;
link.target = '_blank';
link.style.display = 'none';
document.body.appendChild(link);
// 触发点击
link.click();
// 而后移除
document.body.removeChild(link);
link = null;
}
加参数:
export function generateQS(baseurl, paramObj) {
let returnUrl = baseurl + '?'
for (const key in paramObj) {
// Object.hasOwnProperty(prop)用来判断对象是否含有指定属性
// 返回值boolean
if (paramObj.hasOwnProperty(key)) {
const element = paramObj[key];
returnUrl += key + '=' + element + '&';
}
}
return returnUrl;
}
借助HTML5 Blob实现文本信息文件下载
const funDownload = function (content, filename) {
// 创立暗藏的可下载链接
let eleLink = document.createElement('a');
eleLink.download = filename;
eleLink.style.display = 'none';
// 字符内容转变成blob地址
let blob = new Blob([content]);
eleLink.href = URL.createObjectURL(blob);
// 触发点击
document.body.appendChild(eleLink);
eleLink.click();
// 而后移除
document.body.removeChild(eleLink);
};
借助Base64实现任意文件下载
let funDownload = function (domImg, filename) {
// 创立暗藏的可下载链接
let eleLink = document.createElement('a');
eleLink.download = filename;
eleLink.style.display = 'none';
// 图片转base64地址
let canvas = document.createElement('canvas');
let context = canvas.getContext('2d');
let width = domImg.naturalWidth;
let height = domImg.naturalHeight;
context.drawImage(domImg, 0, 0);
// 如果是PNG图片,则canvas.toDataURL('image/png')
eleLink.href = canvas.toDataURL('image/jpeg');
// 触发点击
document.body.appendChild(eleLink);
eleLink.click();
// 而后移除
document.body.removeChild(eleLink);
};
结束语
在Chrome浏览器下,模仿点击创立的a元素即便不append到页面中,也是能够触发下载的,然而在Firefox浏览器中却不行,因而,下面的funDownload()办法有一个appendChild和removeChild的解决,就是为了兼容Firefox浏览器。
一般下载 && Vue文件图片下载解决
发表回复