Electron中文手册
  • 文档概述
  • 开发指南目录
  • 构建说明(Linux)
  • 构建说明(macOS)
  • 构建说明(Windows)
  • 构建系统概述
  • 编码规范
  • 在 macOS 中调试
  • 在 Windows 中调试
  • 在C ++代码中使用clang-format
  • 在调试器中设置符号服务器
  • 源代码目录结构
  • Chrome升级清单
  • Chromium 开发指南
  • V8 开发指南
  • 教程目录
    • 关于 Electron
    • Electron 版本说明
    • API弃用说明
    • 快速入门
    • 支持的平台
    • 桌面环境集成
    • 系统通知
    • 离屏渲染
    • 在线/离线事件检测
    • 多线程
    • REPL
    • 键盘快捷键
    • DevTools扩展
    • 使用原生模块
    • 使用 Pepper Flash 插件
    • 使用 Selenium 和 WebDriver
    • 使用 Widevine CDM 插件
    • 应用分发
    • 应用打包
    • 主进程调试
    • 使用 node-inspector 进行主进程调试
    • 使用 VSCode 进行主进程调试
    • Mac App Store应用提交指南
    • Windows App Store应用提交指南
    • 安全,本地功能和你的责任
    • Headless CI Systems 测试
  • API接口目录
    • API接口之公用接口
      • 应用语言
      • 开发概要
      • 专业术语
      • 常见问题
      • 环境变量
      • 快捷键字符串
      • 命令行
      • 客户端请求
      • 剪贴板
      • <File> H5 File文件操作
      • 无框窗口
      • <window.open> window.open打开新窗口或打开时传递消息
      • 沙盒选项
    • API接口之主进程接口
      • 整体控制
      • 全局快捷键
      • 图标创建与应用
      • 屏幕
      • 窗口
      • 菜单
      • 菜单项
      • 系统托盘
      • 网页内容
      • 从主进程到渲染进程的异步通信
      • 对话框
      • 创建和控制视图
      • 会话
      • 会话,缓存和代理等控制
      • 页面请求
      • HTTP/HTTPS请求处理
      • 协议的注册和处理
      • 使用系统默认应用程序管理文件或URL
      • 下载项管理
      • 进程控制
      • Chromium原生网络库
      • 获取系统首选项
      • 电源状态
      • 节能管理
      • 调试工具
      • 奔溃报告
      • 性能数据收集
      • 自动更新
      • TouchBar触摸条
      • TouchBar触摸条按钮
      • TouchBar触摸条拾色器
      • TouchBar触摸条分组
      • TouchBar触摸条scrubber
      • TouchBar触摸条分段控件
      • TouchBar触摸条label标签
      • TouchBar触摸条弹出框
      • TouchBar触摸条滑块
      • TouchBar触摸条间隔符
    • API接口之渲染进程接口
      • 页面渲染
      • <webview> webview标签
      • 渲染进程与主进程通信
      • 从渲染进程到主进程的异步通信
      • 子窗口
      • 捕获桌面资源
  • 结构列表
    • 蓝牙设备对象
    • 证书对象
    • 证书主体对象
    • Cookie对象
    • 崩溃报告对象
    • 桌面捕获源对象
    • 显示器对象
    • 打印机信息对象
    • 文件过滤器对象
    • 最近使用的项目
    • 常用列表项
    • CPU使用率对象即程序占用的CPU资源
    • IO值对象
    • 内存信息对象
    • 进程内存信息对象
    • 内存使用详细信息
    • Mime类型缓冲区
    • 矩形对象
    • 删除客户端证书对象
    • 删除密码对象
    • Scrubber项对象
    • 分段控制对象
    • 快捷方式对象
    • 任务对象
    • 缩略图工具栏按钮对象
    • 上传blob对象
    • 上传数据对象
    • 上传文件系统对象
    • 上传文件对象
    • 上传原始数据对象
Powered by GitBook
On this page
  • 实例事件
  • 事件: 'updated'
  • 事件: 'done'
  • 实例方法
  • downloadItem.setSavePath(path)
  • downloadItem.getSavePath()
  • downloadItem.pause()
  • downloadItem.isPaused()
  • downloadItem.resume()
  • downloadItem.canResume()
  • downloadItem.cancel()
  • downloadItem.getURL()
  • downloadItem.getMimeType()
  • downloadItem.hasUserGesture()
  • downloadItem.getFilename()
  • downloadItem.getTotalBytes()
  • downloadItem.getReceivedBytes()
  • downloadItem.getContentDisposition()
  • downloadItem.getState()
  • downloadItem.getURLChain()
  • downloadItem.getLastModifiedTime()
  • downloadItem.getETag()
  • downloadItem.getStartTime()

Was this helpful?

  1. API接口目录
  2. API接口之主进程接口

下载项管理

Previous使用系统默认应用程序管理文件或URLNext进程控制

Last updated 4 years ago

Was this helpful?

控制从远程源的文件下载。

进程:

DownloadItem(下载项)是一个在Electron中展示下载项的

它被用于 Session类中的 will-download事件,并允许用户控制下载项。

//主进程中
const {BrowserWindow} = require('electron')
let win = new BrowserWindow()
win.webContents.session.on('will-download', (event, item, webContents) => {
//设置保存路径,使Electron不提示保存对话框。
  item.setSavePath('/tmp/save.pdf')

  item.on('updated', (event, state) => {
    if (state === 'interrupted') {
      console.log('下载已中断,但可以恢复')
    } else if (state === 'progressing') {
      if (item.isPaused()) {
        console.log('下载已暂停')
      } else {
        console.log(`Received bytes: ${item.getReceivedBytes()}`)
      }
    }
  })
  item.once('done', (event, state) => {
    if (state === 'completed') {
      console.log('下载成功')
    } else {
      console.log(`下载失败: ${state}`)
    }
  })
})

实例事件

事件: 'updated'

触发:下载获得更新且未完成时

  • event Event

  • state String,可选以下状态:

    • progressing - 下载正在进行中。

    • interrupted - 下载已中断但可以恢复。

事件: 'done'

触发:下载处于完成状态(如已完成,被 downloadItem.cancel()取消,意外中断)

  • event Event

  • state String,可选以下状态:

    • completed - 下载已成功完成。

    • cancelled - 下载已取消。

    • interrupted- 下载已中断,无法恢复。

实例方法

downloadItem.setSavePath(path)

用途:设置下载目录

  • path String - 下载项目的保存路径。

API仅在会话的 will-download 回调函数中可用。 如果用户未通过API设置保存路径,Electron将使用原始保存路径(通常提示保存对话框)。

downloadItem.getSavePath()

用途:返回下载目录

通过 downloadItem.setSavePath(path) 设置的路径或从保存对话框中选择的路径。

downloadItem.pause()

用途:暂停下载

downloadItem.isPaused()

用途:判断下载是否已被暂停

downloadItem.resume()

用途:恢复已暂停的下载

注意: 要启用可继续的下载项,您正在下载的服务器必须支持范围请求,并提供 Last-Modified和 ETag头值。 否则 resume()将关闭以前收到的字节,并从头开始重新下载。

downloadItem.canResume()

用途:判断下载是否可以恢复

downloadItem.cancel()

用途:取消下载

downloadItem.getURL()

用途:获取下载项的链接地址

downloadItem.getMimeType()

用途:获取下载项的文件mime类型

downloadItem.hasUserGesture()

用途:判断下载是否具有用户手势

downloadItem.getFilename()

用途:获取下载项的文件名

注意:文件名不一定与保存在本地磁盘中的实际文件名相同。如果用户在提示的下载保存对话框中更改文件名,则保存文件的实际名称将不同。

downloadItem.getTotalBytes()

用途:获取下载项的文件大小(以bytes字节为单位) 如果大小未知,则返回0。

downloadItem.getReceivedBytes()

用途:获取下载项的已接收字节数(以bytes字节为单位)

downloadItem.getContentDisposition()

用途:获取下载项的响应头的Content-Disposition字段(字符串)

downloadItem.getState()

用途:获取下载项的当前状态

可以是 progressing下载中, completed已完成, cancelled已取消, interrupted中断且无法恢复.

注意:以下方法适用于在会话重新启动时恢复 cancelled项。

downloadItem.getURLChain()

用途:获取下载项的完整下载链接(包含任何重定向)(字符串)

downloadItem.getLastModifiedTime()

用途:获取下载项的Last-Modified标头值(字符串)

downloadItem.getETag()

用途:获取下载项的ETag头值(字符串)

downloadItem.getStartTime()

用途:获取下载项的开始下载时间(秒级)(字符串)

EventEmitter
主进程