Vue:如何实现日志导出下载功能?

提示:当前日志导出下载功能,是基于后端接口返回的日志数据url地址进行操作。
提示:当前日志导出下载功能,是基于后端接口返回的日志数据url地址进行操作。
提示:当前日志导出下载功能,是基于后端接口返回的日志数据url地址进行操作。

文章目录


1.后端接口返回数据示例

javascript 复制代码
{
       "status": 0,
       "data": {
               "file_url": "http://test//tmp/log.bin"
       }
}

提示:基于类似上述文件地址 实现导出下载功能


2.关键代码

html 复制代码
  <button @click="exportLog()">导出</button >
javascript 复制代码
        exportLog(){
            logApi().then((res) => {
                if (res.status == 0) {
                    const now = new Date();
                    const year = now.getFullYear();
                    const month = ('0' + (now.getMonth() + 1)).slice(-2);
                    const day = ('0' + now.getDate()).slice(-2);
                    const hours = ('0' + now.getHours()).slice(-2);
                    const minutes = ('0' + now.getMinutes()).slice(-2);
                    const seconds = ('0' + now.getSeconds()).slice(-2);

                    const formattedTime = year + month + day + hours + minutes + seconds;
                    const link = document.createElement('a');
                    const blob = new Blob([res.data.file_url]);
                    link.style.display = 'none'
                    link.href = URL.createObjectURL(blob)
                    link.setAttribute('download', 'config_'+formattedTime+'.bin')
                    //setAttribute,第二个参数是定义导出文件的名称。
                    document.body.appendChild(link)
                    link.click()
                    document.body.removeChild(link)
                }
            });
		},
相关推荐
2503_928411562 小时前
12.18 中后台项目-权限管理
前端·javascript·数据库
hssfscv2 小时前
JAVAweb学习笔记——JS
javascript·笔记·学习
茶憶3 小时前
UniApp 安卓端实现文件的生成,写入,获取文件大小以及压缩功能
android·javascript·vue.js·uni-app
信看11 小时前
NMEA-GNSS-RTK 定位html小工具
前端·javascript·html
爱吃大芒果11 小时前
Flutter 主题与深色模式:全局样式统一与动态切换
开发语言·javascript·flutter·ecmascript·gitcode
king王一帅11 小时前
流式渲染 Incremark、ant-design-x markdown、streammarkdown-vue 全流程方案对比
前端·javascript·人工智能
whyfail13 小时前
Vue原理(暴力版)
前端·vue.js
踢球的打工仔13 小时前
jquery的基本使用(3)
前端·javascript·jquery