博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
小程序分包加载
阅读量:6453 次
发布时间:2019-06-23

本文共 4161 字,大约阅读时间需要 13 分钟。

开发者需要将小程序划分成不同的子包,在构建时打包成不同的分包,用户在使用时按需进行加载。

 

在构建小程序分包项目时,构建会输出一个或多个分包。每个使用分包小程序必须包含

一个主包,所谓的主包,即放置默认启动页/TabBar 页面,以及一些所有分包需要用到

整个小程序所有分包大小不超过 8M单个分包/主包大小不能超2M

对小程序进行分包,可以优化小程序首次启动的下载时间,以及在多团队共同开发时可以更高的解耦协作。

配置方法:

假设支持分包的小程序目录结构

├── app.js├── app.json├── app.wxss├── packageA│   └── pages│       ├── cat│       └── dog├── packageB│   └── pages│       ├── apple│       └── banana├── pages│   ├── index│   └── logs└── utils

开发者通过在 app.json subPackages 字段声明项目分包结构:

{  "pages":[    "pages/index",    "pages/logs"  ],  "subpackages": [    {      "root": "packageA", "pages": [ "pages/cat", "pages/dog" ] }, { "root": "packageB", "name": "pack2", "pages": [ "pages/apple", "pages/banana" ] } ] }

subPackages 中,每个分包的配置有以下几项:

字段 类型 说明
root String 分包根目录
name String 分包别名,时可以使用
pages StringArray 分包页面路径,相对与分包根目录
independent Boolean 分包是否是

 

打包原则

  声明 subPackages 后,将按 subPackages 配置路径进行打包,subPackages 配置路径外的目

  录将被打包到 app(主包) 中

  app(主包)也可以有自己的 pages(即最外层的 pages 字段)

  subPackage 的根目录不能是另外一个 subPackage 内的子目录

  tabBar 页面必须在 app(主包)内

引用原则

  packageA 无法 require packageB JS 文件,但可以 require app、自己 package 内的 JS 文件

  packageA 无法 import packageB template,但可以 require app、自己 package 内的 template

  packageA 无法使用 packageB 的资源,但可以使用 app、自己 package 内的资源

独立分包

  独立分包是小程序的一种特殊类型的分包,可以独立于主包和其他分包独立运行。从独立

  分包中页面进入小程序时,不需要下载主包,当小程序进入不同分包的时候,主包才会被下载。

  可发者可以按需将某些具有一定功能独立性的页面配置到独立分包中。当小程序从普通的

  分包页面中启动时,需要首先下载主包;而独立分包不依赖主包即可运行,可以很大程度上

  提升分包页面的启动速度, 一个小程序中可以有多个独立分包。

配置方法:

  假设小程序的目录如下;

  ├── app.js  ├── app.json  ├── app.wxss  ├── moduleA  │   └── pages  │       ├── rabbit  │       └── squirrel  ├── moduleB  │   └── pages  │       ├── pear  │       └── pineapple  ├── pages  │   ├── index  │   └── logs  └── utils

  开发者可以通过在  app.json subpackages 字段中的分包配置中自定义 independent

  字段声明对应分包为独立分包

  {      "pages": [        "pages/index",        "pages/logs"      ],     "subpackages": [        {          "root": "moduleA",      "pages": [     "pages/rabbit",      "pages/squirrel"     ]     }, {     "root": "moduleA",     "pages": [     "pages/pear",     "pages/pineapple"     ],   "independent": true   }   ]   }

限制:

  独立分包属于分包的一种,普通分包的所有限制独立分包有效。独立分包中插件

  自定义组件的处理方式同普通分包。

 

使用独立分包需要注意:

  独立分包中不能依赖主包和其他分包中的内容,包括js 文件,template,

  wxss,自定义组件,插件等,主包的app.wxss 对独立分包无效。应避免在

  独立分包页面中使用 app.wxss 中的样式。

  App 只能在主包中定义,独立分包中不能定义 App 会造成无法预期的行为。

  独立分包中暂时不支持使用插件。

注意事项:

  (1) 关于 getApp()

    与普通分包不同,独立分包运行时,App 并不一定被注册,因此,getApp()

    也不一定获得App 对象,

     当用户从独立分包页面启动小程序时,主包不存在,App 也不存在,此时调用

    getApp 获取到的是undefined 。当用户进入普通分包或者主包时,主包才会

    被下载, App 才会被注册。

    当用户从普通分包或者主包的页面挑到独立分包的时候,主包已经存在,此时

    调用getApp(),才能获得真正的App

    

为了满足独立分包中的这一需求,基础库2.2.4  版本开始getApp 支持,

 

  allowDefault 参数,在 App 未定义的时候返回一个默认实现。当主包

 

  加载 App 被注册的时候,默认实现中被定义的属性会被合并覆盖到默认的App 中。

 

 

 

  示例:

 

    const  app = getApp({allowDefault:true})  // {}

 

      app.data = 456

 

      app.global = {}

 

     .app.js  

 

      App({

 

        data:123

 

        other:'hello'

 

      })

 

     console.log(getApp())   // {global: {} ,data: 456,other: 'hello'}

  (2) 关于 App 的生命周期

     当从独立分包中启动小程序时,主包的中的onLanch 和首次 onShow  会从

    独立分包页面首次进入主包或普通分包页面时调用。

 

分包下载:

  开发者可以通过配置,在进入小程序某个页面时,由框架自动预下载可需要的分包。

  提升进入后续分包页面的速度,对于独立分包,可以预下载主包。

配置方法:

  预下载分包行为在进入某个页面的时候触发,在通过app.json 增加 preloadRule

 

{
"pages": ["pages/index"],  "subpackages": [    {      "root": "important", "pages": ["index"], }, { "root": "sub1", "pages": ["index"], }, { "name": "hello", "root": "path/to", "pages": ["index"] }, { "root": "sub3", "pages": ["index"] }, { "root": "indep", "pages": ["index"], "independent": true } ], "preloadRule": { "pages/index": { "network": "all", "packages": ["important"] }, "sub1/index": { "packages": ["hello", "sub3"] }, "sub3/index": { "packages": ["path/to"] }, "indep/index": { "packages": ["__APP__"] } } }
 

  preloadRule  中,key  是页面路径, value  是进入此页面的 预下载配置,每个配置都

  有以下几项。 

字段

类型

必填

默认值

说明

packages

StringArray

进入页面后预下载分包的 root  name。__APP__ 表示主包。

network

String

wifi

在指定网络下预下载,可选值为:

all: 不限网络 

wifi: wifi下预下载

  限制

    同一个分包中的页面享有共同的预下载大小限额2M,会在工具打包时校验。

    如:页面A 和页面B 都在同一个分包中,A 中预下载大小为0.5 M的分包,

    B 中最大多只能预下载大小1.5 的分包。

 

 

 详细请参考 https://developers.weixin.qq.com/miniprogram/dev/framework/subpackages.html

 

转载于:https://www.cnblogs.com/nmxs/p/9826966.html

你可能感兴趣的文章
通过原生js添加div和css
查看>>
简单的导出表格和将表格下载到桌面上。
查看>>
《ArcGIS Engine+C#实例开发教程》第一讲桌面GIS应用程序框架的建立
查看>>
递归查询上一级
查看>>
JAVA - 大数类详解
查看>>
查询指定名称的文件
查看>>
批处理文件
查看>>
1.每次按一下pushbutton控件,切换图片?
查看>>
Python 嵌套列表解析
查看>>
[GXOI/GZOI2019]旧词——树链剖分+线段树
查看>>
android 补间动画的实现
查看>>
2017年广东省ACM省赛(GDCPC-2017)总结
查看>>
第十届蓝桥杯B组C++题目详解和题型总结
查看>>
树的存储结构2 - 数据结构和算法42
查看>>
函数的嵌套调用
查看>>
OC中使用 static 、 extern、 const使用
查看>>
简单理解函数回调——同步回调与异步回调
查看>>
POJ 1007
查看>>
Android 多个Activity 跳转及传参
查看>>
中文文本预处理流程(带你分析每一步)
查看>>