This is the 13th day of my participation in the August More Text Challenge. For details, see:August is more challenging

preface

When I was developing my personal project on the mobile phone, I wanted to have a mobile APP to display my website, which could be used without the network.

Then came the search for how to convert H5 into an APP in Baidu.

I found a lot of them, some of them are the shell (type in the url and package the APP, which is actually a browser), and SOME of them are HB’s cloud package and Cordova. Cordova seems to be very powerful, but I still use Hbuiler’s cloud package for convenience (I won’t say I built it for a long time).

Native-js is a library provided by Hbuiler, which provides mobile platform apis for front-end applications, such as listening to the phone lock screen, making calls directly, switching Bluetooth… And so on.

Packaging APP

This is typically done by adding a configuration file called manifest.json to the project’s packaged folder, which can be used to see what the properties do in Hbuiler.

It should be noted that there is no command for cloud packaging (local packaging is dead) so that it is easier to write the online process in Gulp.

Hot update

What is a hot update?

In fact, the term is familiar to all of you, the user does not have to reinstall the latest app to get the latest content, this technology is widely used in games.

Hbuiler hot update is also very simple, we first create a WGT package in Hbuiler, this package is the focus of hot update, when the user downloads the package in the APP and directly install it can be hot update.

We now write in the code:

/ / download API
plus.downloader.createDownload('WGT download address', {}, (data, status) = > {
    if(status == 200) {console.log('Download successful')
        / / install API
        plus.runtime.install(data.filename, {}, () = > {
            console.log('WGT file installed successfully')
            / / restart API
            plus.runtime.restart();
        }, (err) = > {console.log('Download failed', err)})
    } else{
        console.log('Download failed')
    }
}).start();
Copy the code

The above code should provide us with a hot update capability.

The WGT package will be downloaded every time the call is made. We can determine whether the latest version in the server is more up-to-date than the local version before the call is made. If so, download the WGT package.