Mini Program Operation Mechanism
Download
Mini program does not need installation. When it is used for the first time by the user, AppContainer downloads resources of the Mini Program from the server. The downloaded Mini Program resources are cached in the mobile app client for some time. When the Mini Program with cached resources is opened again, the download process is skipped so the Mini Program is opened faster.
Hot Startup and Cold Startup
- Cold startup: When the user opens a Mini Program that has not been started or has been destroyed, this is called a cold startup. Here, the Mini Program starts the initialization process. When the process is completed, it triggers the onLaunchcallback function.
- Hot startup: When the user opens a Mini Program that has been opened but is running in background, this is called the hot startup. Here, the Mini Program is not destroyed and restarted. Instead, it is switched from background to foreground. The onLaunchcallback function is not triggered.
Foreground/Background Running
- Foreground running: When the user opens a Mini Program for the first time, the Mini Program runs in the foreground.
- Background running: When the user clicks the close button in the top-right corner to close the Mini Program or press the Home button to leave mobile App, the Mini Program is not destroyed but switched to background.
- Switching from background to foreground: When the Mini Program that has not been destroyed by the system is reopened or reactivated, it is switched from background to foreground.
The callback function for foreground/background switching can be registered in app.js. When the Mini Program switches from background to foreground, it triggers onShow; conversely it triggers onHide.
Cache
The local cache system can provide store, get and remove ability to control cache. A Mini Program can store at most 10 MB data. There are two types of API: sync API and async API. The sync API will block current task until the method ends and sync API will not block current task.
| Operation | Sync API | Async API | Description | 
| Store | my.setStorageSync | my.setStorage | Store the data according to the key, the original data will be overwrite if thekeyis the same. | 
| Get | my.getStorageSync | my.getStorage | Read cache data | 
| Remove | my.removeStorageSync | my.removeStorage | Remove specific data | 
| Clear | my.clearStorageSync | my.clearStorage | Clear all the cache data | 
Destroy
When the user clicks the close button in the top-right corner to close the Mini Program, the Mini Program is not destroyed but switched to background. Only when the Mini Program stays in background for some time or the system resource consumption is too high, it is really destroyed.