下载事件
win.webContents.downloadURL(url)文章来源:https://www.toymoban.com/news/detail-657037.html
触发session的will-download事件
win.webContents.session.on('will-download', (event, downloadItem, webContents) => {
// 设置文件保存路径
// 如果用户没有设置保存路径,Electron将使用默认方式来确定保存路径(通常会提示保存对话框)
item.setSavePath(savePath)
item.on('updated', (event, state) => {
// 监听下载过程, state有两种情况
// interrupted 下载被中断,可恢复
// progressing 下载进行中,可获取下载进度
if (state === 'interrupted') {
// 可恢复下载
} else if (state === 'progressing') {
if (downloadItem.isPaused()) {
console.log('Download is paused')
} else {
// 可以根据字节大小设置进度条
console.log(`Total bytes: ${downloadItem.getTotalBytes()}`)
console.log(`Received bytes: ${downloadItem.getReceivedBytes()}`)
}
}
})
item.once('done', (event, state) => {
// 下载结束
if (state === 'completed') {
// 下载成功
console.log('Download successfully')
// 用应用程序打开文件
openFile(downloadItem.getSavePath())
} else {
// state为cancelled或interrupted
// 下载取消或下载已经中断,无法恢复
console.log(`Download failed: ${state}`)
}
// 这里可将下载结束的状态传回给渲染进程
win.webContents.send('downstate', state)
})
})
shell 使用默认应用程序管理文件和 url,提供与桌面集成相关的功能
shell.openPath(path) 以桌面的默认方式打开给定的文件。文章来源地址https://www.toymoban.com/news/detail-657037.html
function openFile(filePath) {
const path = require('path');
shell.openPath(path.join(filePath));
}
到了这里,关于vue+electron中实现文件下载打开wps预览的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!