a标签模拟下载

简介: a标签模拟下载
/**
 * a标签下载
 *
 * @param {*} url 链接
 * @param {*} options 参数 { payload: url携带参数 }
 * @returns {Boolean} success
 */
export function downloadByLink(url, options) {
    if (!url) return false

    const a = document.createElement('a')

    // 添加属性
    let href = url
    const {
        payload,
        ...attrs
    } = options || {}
    attrs.href = payload ? (href += '?' + qs.stringify(payload)) : href
    Object.entries(attrs).forEach(([key, value]) => {
        a.setAttribute(key, value)
    })
    a.setAttribute('target', '_self')

    // 触发下载
    document.body.appendChild(a)
    a.click()
    a.onclick = e => {
        e && e.preventDefault()
    }
    a.parentNode.removeChild(a)

    return true
}

加载script

/**
 * 加载脚本
 *
 * @param {String} src 地址
 * @param {*} options 属性 { autoremove: 用完就扔, ... }
 *
 * @returns {Promise}
 *
 * @throws {Error}
 */
export function loadScript(src, options) {
    const {
        autoremove = true, ...attrs
    } = options || {}
    return new Promise((resolve, reject) => {
        const script = document.createElement('script')
        Object.entries(attrs).forEach(([key, val]) => {
            script.setAttribute(key, val)
        })
        script.src = src
        script.onload = () => {
            if (autoremove) {
                script.onload = script.onerror = null
                document.head.removeChild(script)
            }
            resolve()
        }
        script.onerror = reject
        document.head.appendChild(script)
    })
}

Blob文件转换下载

// Blob文件转换下载
export const downBlobFile = (result, fileName, fileType = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8;', submitEndDo ? , timeSuffix = true) => {
    const data = result
    const blob = new Blob([data], {
        type: fileType
    })
    if (timeSuffix) {
        // 默认导出的文件名称添加时间
        const time = moment(new Date()).format('YYYY-MM-DD HH:mm:ss')
        fileName = fileName + ' ' + time
    }
    if (window.navigator && window.navigator.msSaveOrOpenBlob) {
        // for IE
        // IE必须给文件名设置固定后缀,不然默认会是.txt
        window.navigator.msSaveOrOpenBlob(blob, fileName + '.xlsx')
    } else {
        // for Non-IE (chrome, firefox etc.)
        const objectUrl = URL.createObjectURL(blob)
        const a = document.createElement('a')
        a.setAttribute('style', 'display:none')
        a.setAttribute('href', objectUrl)
        a.setAttribute('download', fileName)
        a.click()
        URL.revokeObjectURL(objectUrl)
    }
    if (submitEndDo) {
        submitEndDo()
        submitEndDo = null
    }
}
目录
相关文章
|
JavaScript 前端开发
JS 下载 URL 链接文件(点击按钮、点击a标签、支持代理与非代理下载)
JS 下载 URL 链接文件(点击按钮、点击a标签、支持代理与非代理下载)
636 0
|
Web App开发 移动开发 JavaScript
【前端用法】HTML5 Video标签如何屏蔽右键视频另存为的js代码以及如何禁用浏览器控件,Video 禁止鼠标右键下载
【前端用法】HTML5 Video标签如何屏蔽右键视频另存为的js代码以及如何禁用浏览器控件,Video 禁止鼠标右键下载
384 0
|
8月前
|
前端开发 JavaScript
前端js代码一句话模拟Ctrl+A全选网页内容效果document.execCommand(‘selectAll‘);
前端js代码一句话模拟Ctrl+A全选网页内容效果document.execCommand(‘selectAll‘);
|
8月前
|
搜索推荐 前端开发 UED
html页面实现自动适应手机浏览器(一行代码搞定)
html页面实现自动适应手机浏览器(一行代码搞定)
758 0
|
8月前
|
Web App开发 定位技术
Chrome中实现使用迅雷一次性选中并下载网页内全部链接的方法
Chrome中实现使用迅雷一次性选中并下载网页内全部链接的方法
181 1
|
8月前
|
JSON JavaScript 前端开发
用js脚本下载某书的所有文章
用js脚本下载某书的所有文章
76 0
Pyhton 使用浏览器打开本地 html(打开指定页面、新建标签栏 ....)
Pyhton 使用浏览器打开本地 html(打开指定页面、新建标签栏 ....)
148 0
|
Web App开发 JavaScript 安全
window.open(url)多次打开下载链接被浏览器拦截问题解决方案,js实现循环访问多个下载链接
window.open(url)多次打开下载链接被浏览器拦截问题解决方案,js实现循环访问多个下载链接
815 0
window.open(url)多次打开下载链接被浏览器拦截问题解决方案,js实现循环访问多个下载链接
IDM - 如何去除浏览器下载浮动条?
IDM - 如何去除浏览器下载浮动条?
608 0
IDM - 如何去除浏览器下载浮动条?