码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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. },

  • 相关阅读:
    当我们谈数据分析时,到底在谈什么?
    SpringBoot中最常用的5个内置对象
    信息学奥赛一本通:1143:最长最短单词
    【MongoDB】索引 – 通配符索引
    基于51单片机和DHT11温湿度传感器的智能加湿器的设计与实现
    postman设置接口关联这样做,薪资直接涨3k
    最佳使用案例NO.1–干涉测量
    C#访问修饰符
    力扣刷题记录106.1-----322. 零钱兑换
    idea的macOS Apple Silicon (dmg)版本和macOS (dmg)版本有什么区别
  • 原文地址:https://blog.csdn.net/qq_35119405/article/details/126600406
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号