• vue独立提供模板下载功能


    需求描述:页面需要下载模板文件(word、excel),这些文件是固定的,如果存储在服务端,由后端负责返回数据流,前端再处理数据流则太浪费性能。把文件放到前端,用户下载时直接提供。但是传统的前端项目(html/css/js)是无法做到获取文件。

    1.将这部分静态的文件放入到public目录

    可以参考命名一个static的文件夹,将所有静态资源放入到该文件夹中

    放入public的文件最终会直接打包到前端服务器

    当然,还有另外一种方法。静态资源文件可以放置在src目录下的static文件夹,然后通过copy-webpack-plugin,在webpack的配置文件中为static文件夹配置复制处理的操作,在此不做演示,有兴趣可以自己试试。

    直接复制到public比较粗暴,比较直接

    2.验证

    打包后的文件,已经可以通过服务器访问到这个资源。运行项目,通过localhost:8080访问项目正常,在8080后面接我们的文件路径即可获得一个下载链接,如:localhost:8080/static/files/userTemplate.xls

    打开这里链接即可自动下载

     

    3.编写代码

    用户如何触发下载?点击下载时通过window对象获取当前网页的域名(ip)端口号等,触发下载事件

    1. loadDownImportExcel(){
    2. let xieyi = window.location.href.split("://")[0];
    3. let host = window.location.host;
    4. let pathname = window.location.pathname
    5. let baseUrl = xieyi + '://' + host + pathname
    6. const link = document.createElement('a')
    7. link.style.display = 'none'
    8. link.setAttribute('href', baseUrl + '/static/files/userTemplate.xls')
    9. link.download = '用户导入模板' + new Date().getTime() //下载的文件名
    10. document.body.appendChild(link)
    11. link.click()
    12. document.body.removeChild(link)
    13. },

  • 相关阅读:
    shell 运算符
    万字长文Python面试题
    ARM——cortex-A7核 按键中断实验
    计算机毕设(附源码)JAVA-SSM基于web的医院门诊管理系统
    高薪程序员&面试题精讲系列117之怎么保证Redis缓存与数据库的数据一致性?
    JoySSL:免费SSL证书的新选择
    SpringBoot实用开发篇复习4(实用开发篇完)
    adb不是内部或外部命令
    python和SciPy速成
    福云玩具销售系统
  • 原文地址:https://blog.csdn.net/qq_35119405/article/details/126600406