preface

The Company’s React Native app update (non-hot update) was completed this week, so here’s a summary.

1. First, ask a question

Our APP (based on RN) already has a hot update feature, why do we need an update feature?

Because hot updates only update non-native code and resources (images, JS). Some functions must call Native code and resources (such as wechat payment, etc.). At the beginning, our app did not have the function of notification push at the beginning. To add this function, the app needs to introduce the Native code of a third party. At this time, users need to download the software in app Store (Android App is located in Dandelion) and install the software to update the software. That is, when the APP needs to update Native codes and resources, it needs to have this update function.

2. Implementation idea of update function (non-native implementation)

At present, we have temporarily adopted a notification function in our app (an independent function related to business, and the notification content is customized by background management). When the APP is updated, users can receive the notification in the APP. After clicking the notification, there will be an update button. After clicking the button, on ios, you will be redirected to the App Download page in the App Store. On Android, the default browser is used to jump to the download page of the APP. In this way, users can go to the download page of the app to update the app.

3. Specific code implementation

  • Linking API in RN is used.
// Determine the phone system to get the app download address (iosDownloadUrl and androidDownloadUrl are variables) const downloadUrl = platform. OS ==='ios'? iosDownloadUrl : androidDownloadUrl; // Open the download address // ios open the download address will jump to the download page of app Store app // how to obtain the download address of ios app? 👇 // Android will open the default browser and enter the address Linking. OpenURL (downloadUrl). Catch (err => {// when error occurs //... });Copy the code

4. Other

(1) How to obtain the download address of ios app?

Open iTunes on your computer, click search in the upper right corner, search for your app name, and then click the drop down arrow to the right of “Get” to see the copy link. Click the Copy link.

(2) Disadvantages of this scheme

  • The update function depends very much on the notification function of our app. If the user has not logged in, he or she cannot receive the notification, so he or she cannot update
  • The user will always see the notification, and we can’t deny the notification to the user based on whether or not the user has updated the app, because we can’t tell whether or not the user has updated the app

5. Deficiencies of the current program and future improvement programs

insufficient

  • The updated functionality is dependent on the business functionality (notification functionality) and heavily coupled with notification functionality
  • Only logged-in users can receive the notification function and update the app

The improved scheme

  • Use the local version number of the app to compare with the version number of the app server (app Store server or your own server) to determine whether the user needs to update