【vue】下载字符串拼接的文件链接并重命名文件

news/2024/7/10 2:08:44 标签: vue, js

vue】下载字符串拼接的文件链接并重命名文件


字符串拼接链接代码示例:

this.url = "http://127.0.0.1:8080/test/upload/20210128/2b35f9d7a64c3a6455a6e596c5c70fd7.xlsx";
this.filename = "导出文件";
this.html = '<button type="button" class="el-button el-button--primary el-button--small"><i class="el-icon-download"></i><a style="color:#fff;outline:none;" οnclick=download("'+this.url+'","'+this.filename+'.xlsx")  href="#">下载</a></button>';

定义window函数

<script>
window.downloadFile = function (url,filename) {
  getBlob(url, function(blob) {
      saveAs(blob, filename);
  })
};

function getBlob(url,cb) {
    var xhr = new XMLHttpRequest();
    xhr.open('GET', url, true);
    xhr.responseType = 'blob';
    xhr.onload = function() {
        if (xhr.status === 200) {
            cb(xhr.response);
        }
    };
    xhr.send();
}
/**
 * 保存
 * @param  {Blob} blob
 * @param  {String} filename 想要保存的文件名称
 */
function saveAs(blob, filename) {
  if (window.navigator.msSaveOrOpenBlob) {
      navigator.msSaveBlob(blob, filename);
  } else {
    var link = document.createElement('a');
    var body = document.querySelector('body');

    link.href = window.URL.createObjectURL(blob);
    link.download = filename;

    // fix Firefox
    link.style.display = 'none';
    body.appendChild(link);

    link.click();
    body.removeChild(link);
    window.URL.revokeObjectURL(link.href);
  }
}
</script>

图片示例:
在这里插入图片描述
在这里插入图片描述

说明:
1.downloadFile函数定义到window中生效。


http://www.niftyadmin.cn/n/903319.html

相关文章

【java】按行读写txt文件

【java】按行读写txt文件按行读写txt文件按行读写txt文件 按行读写txt文件 FileReader fr null;FileWriter fw null;try {fr new FileReader("D:\\读.txt");BufferedReader br new BufferedReader(fr);List<String> list new ArrayList<>();String…

【java】lambda表达式之List操作

【java】lambda表达式之List操作【java】lambda表达式之List操作去重过滤抽取分组计数最值匹配求和【java】lambda表达式之List操作 去重 //按学生姓名去重 //可能会改变原有list的顺序 List<Student> list studentList.stream().collect(Collectors.collectingAndThe…

【vue】vue页面使用scss样式

【vue】vue页面使用scss样式 1.引入sass-loader模块【vue】vue页面使用scss样式//这里使用7.0.1版本 npm install sass-loader7.0.12.引入node-sass模块【vue】vue页面使用scss样式//这里使用4.12.0版本 npm install node-sass4.12.03.vue页面使用【vue】vue页面使用scss样式&l…

【java】IDEA在install编译的时候报Error:(30, 17) java: 找不到符号符号: 变量 log

【java】IDEA在install编译的时候报Error:(30, 17) java: 找不到符号符号: 变量 log 如果使用了Slf4j注解&#xff0c;idea需要Lombok插件&#xff0c;或者在maven中配置依赖 方法1.idea安装Lombok插件 方法2.pom.xml配置依赖 <dependency><groupId>org.project…

【vue】avue-crud行编辑

【vue】avue-crud行编辑 1.vue页面代码 <template><avue-crud ref"crud" :option"option" :data"data" row-update"rowUpdate"><template slot-scope"{row,index}" slot"menu"><el-button…

【vue】父页面按钮显示子组件中的el-dialog

1.父页面 <template><div><el-buttontype"primary"icon"el-icon-upload2"size"small"click"openDialog">导入</el-button><uploadDialog ref"uploadDialog" :dialogVisible"dialogVisible…

【java】excel添加颜色和注释

excel添加颜色和注释 package com.util;import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFClientAnchor; import org.apache.poi.xssf.usermodel.XSSFRichTextString; import org.apache.poi…

【java】JsonFormat注解时间导致时区相差8小时问题

//默认是cst&#xff0c;需要指定为gmt JsonFormat(pattern "yyyy-MM-dd HH:mm:ss", timezone"GMT8") ApiModelProperty(value "创建时间") private Date createTime;