# PreDownloadSubpackageTask tap.preDownloadSubpackage(Object object)

# 功能描述

预下载分包,返回预下载任务实例

# 参数

# Object object

属性类型默认值必填说明
packageTypestring'normal'分包的类型,填写 "workers" 后 name 字段失效
合法值说明
workersworker 分包
normal普通分包, 3.4.9及以上版本支持
namestring分包的名字,可以填 name 或者 root。在独立分包内,填 __GAME__ 表示加载主包,详见 小游戏独立分包指南, 3.4.9及以上版本支持
successfunction分包加载成功回调事件
failfunction分包加载失败回调事件
completefunction分包加载结束回调事件(加载成功、失败都会执行)

# 返回值

# PreDownloadSubpackageTask

预下载分包任务实例,用于获取分包预下载状态

# 注意事项

  • tap.preDownloadSubpackage 与 tap.loadSubpackage 的区别: tap.preDownloadSubpackage 只下载代码包,不自动执行代码;tap.loadSubpackage 下载完代码包后会自动执行代码。

# worker 分包示例代码

// 首先要在 app.json / game.json 中配置workers作为分包
{
  "workers": {
    "path": "myWorkersFolder",
    "isSubpackage": true  // true 表示把 worker 打包为分包。默认 false。填 false 时等同于 { "workers": "myWorkersFolder" }
  }
}


// 然后调用 tap.preDownloadSubpackage 下载 worker 分包,下载成功后才可以创建 worker
var task = tap.preDownloadSubpackage({
  packageType: "workers",
  success(res) {
    console.log("load worker success", res)
    tap.createWorker("myWorkersFolder/request/index.js")   // 创建 worker。 如果 worker 分包没下载完就调 createWorker 的话将报错
  },
  fail(res) {
    console.log("load worker fail", res)
  }
})

task.onProgressUpdate(res => {
  console.log(res.progress) // 可通过 onProgressUpdate 接口监听下载进度
  console.log(res.totalBytesWritten)
  console.log(res.totalBytesExpectedToWrite)
})

# 普通分包示例代码

// 首先要在 app.json / game.json 中配置分包
{
    "subPackages": [
      {
        "name": "ModuleA",
        "root": "/ModuleA/"
      }
    ]
}


var task = tap.preDownloadSubpackage({
  name: "ModuleA",
  success(res) {
    console.log("load subpackage success", res)
  },
  fail(res) {
    console.log("load subpackage fail", res)
  }
})

task.onProgressUpdate(res => {
  console.log(res.progress) // 可通过 onProgressUpdate 接口监听下载进度
  console.log(res.totalBytesWritten)
  console.log(res.totalBytesExpectedToWrite)
})