1.下载文件
win.webContents.downloadURL(url)
win.webContents.session.on('will-download', (event, item, webContents) => {
var zipFile = path.join(app.getAppPath(), 'static', item.getFilename())
item.setSavePath(zipFile)
item.on('updated', (event, state) => {
if (state === 'interrupted') {
console.log('Download is interrupted but can be resumed')
} else if (state === 'progressing') {
if (item.isPaused()) {
console.log('Download is paused')
} else {
console.log(`complete:${(item.getReceivedBytes() / item.getTotalBytes() * 100).toFixed(2)}%`)
win.setProgressBar(item.getReceivedBytes() / item.getTotalBytes())
}
}
})
item.once('done', (event, state) => {
})
})
2.zip解压缩
npm i node-unzip-2
const path = require('path')
var fs = require('fs')
var unzip = require("node-unzip-2")
var zipTargetPath = path.join(app.getAppPath(),'static')
var zipFile = path.join(app.getAppPath(),'static','test.zip')
console.log('解压目标目录',zipTargetPath)
console.log('解压文件路径',zipFile)
fs.createReadStream(zipFile).pipe(unzip.Extract({ path: zipTargetPath }))
3.关于下载进度条
- electron自带任务栏的下载进度条,适用于后台下载文件
- 如果想把下载进度渲染至页面中,需要用到进程通信,及:主线程发送下载进度,然后渲染线程preload.js中进行监听,然后在preload.js进行页面操作
- preload.js可直接操作Dom,渲染进度条问题不大
- 如果你的网页是独立的且使用vue进行渲染,此种情况无法操作vue的实例,需要手动操作dom
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了