1. WkWebView time consumes possible nodes
- WKWebView initialization time consumed in the page;
- WkWebView loading JS, CSS, image and other static resources time consumption;
- WKWebView rendering page time consumption;
2. Corresponding to the main time consumption, my solution is as follows
- WKWebView is made a singleton, resident in memory, to avoid the time consumption of instantiation, and avoid the memory consumption caused by a large number of creation;
- Js, CSS and image are cached offline or preloaded in advance to avoid loading at a later time for display and reduce the time consumption of loading static resources.
- We can consider using Native preloading for image. The images in WKWebView are replaced by those loaded by Native.
- There’s nothing to say about page rendering time, just make the page as simple and clear as possible, and work on code optimization. Heavy interaction is placed in native, WKWebView only does rich content display;
The profile design
Main design ideas
- The server side returns a shell file (shell.html) containing JS and CSS content in the header, which can be used as all page shell resources. Native uses shell to instantiate a WKWebView in a singleton way.
- When the user browns the list page, the interface returns the image set contained in each page and the page body content (data interface will be given later). App can choose whether to preload images to improve the response speed of WKWebView (such as wifi).
- After entering the page containing WkWebView, replace the body content in shell.html with the image and body content obtained from the list page and refresh the WkWebView content. It can also read local cache files according to ID to achieve content replacement, which is operable.
Core modules and required methods
1. Resource management module
- Static resources such as JS, CSS and shell. HTML can be conditionally downloaded according to the information returned by the interface and stored in a specified location.
- Can manage static resource files, including: delete cache, update resources and other operations.
- Caches the browsing page data and related field information, and manages these resources, including clearing the old information, searching for the specified page information according to the CORRESPONDING ID, and updating the field information.
WKWebView singleton class
- Generate shell.html file pages in singleton mode;
- Refresh page information according to model;
- Support common js interaction capabilities;
- The proxy method can support getting the necessary page information;