微信小程序中下载xlsx文件

var storeSessionKey = uni.getStorageSync("storeSessionKey");

var that = this;

uni.request({

url: that.$api + '/openapi/storeAdmin/exportSalesData?activityId=' + that.params

.activityId, // 替换为服务器端的文件下载接口地址

method: 'GET',

header: {

"X-Token": storeSessionKey, //自定义请求头信息

},

responseType: 'arraybuffer', // 设置响应类型为字节流

success: function(rest) {

console.log(rest, '圣诞节发货');

if (rest.statusCode === 200) {

const fs = wx.getFileSystemManager(); //获取全局唯一的文件管理器

fs.writeFile({ // 写文件

filePath: wx.env.USER_DATA_PATH +

`/${that.avtName}.xlsx`, // wx.env.USER_DATA_PATH 指定临时文件存入的路径,后面字符串自定义

data: rest.data,

encoding: "binary", //二进制流文件必须是 binary

success(res) {

wx.openDocument({ // 新开页面打开文档

filePath: wx.env.USER_DATA_PATH +

`/${that.avtName}.xlsx`, //拿上面存入的文件路径

showMenu: true, // 允许出现分享功能

success: function(res) {

uni.showToast({

title: "打开成功,请自行发送给好友保存",

icon: "none"

})

setTimeout(() => {

uni.hideLoading()

}, 500)

}

})

},

fail() {

uni.hideLoading()

uni.showToast({

title: "文件走丢了~",

icon: "none"

})

}

});

}

},

fail: function(err) {

console.log('请求失败', err);

}

});

相关推荐
WangHappy5 小时前
不写 Canvas 也能搞定!小程序图片导出的 WebView 通信方案
前端·微信小程序
小时前端10 小时前
微信小程序选不了本地文件?用 web-view + H5 一招搞定
前端·微信小程序·uni-app
icebreaker1 天前
Weapp-vite:原生模式之外,多一种 Vue SFC 选择
前端·vue.js·微信小程序
icebreaker1 天前
重走 Vue 长征路 Weapp-vite:编译链路与 Wevu 运行时原理拆解
前端·vue.js·微信小程序
大米饭消灭者4 天前
Taro是怎么实现一码多端的【底层原理】
微信小程序·taro
FliPPeDround5 天前
Vitest Environment UniApp:让 uni-app E2E 测试变得前所未有的简单
微信小程序·e2e·前端工程化
FliPPeDround5 天前
微信小程序自动化的 AI 新时代:wechat-devtools-mcp 智能方案
微信小程序·ai编程·mcp
吴声子夜歌5 天前
小程序——布局示例
小程序
码云数智-大飞5 天前
如何创建自己的小程序,码云数智与有赞平台对比
微信小程序
luffy54595 天前
微信小程序页面使用类似filter函数的wxs语法
微信小程序·小程序