HLLOfflineWebVC is a lightweight and high-performance hybrid framework developed by HUOLALA mobile team, which is intended to improve the load speed of websites on mobile phone. It base on WKWebView at iOS system.
HLLOfflineWebVC can cache html, css, js, png and other static resource on the disk. When the app load the web page, it directly load the resource from disk and reduce network request. You can get more details from the article.
Before VS After Using HLLOfflineWebVC
Before Using HLLOfflineWebVC | After Using HLLOfflineWebVC | |
---|---|---|
Time Cost | 2s | 1s |
Movie |
Features
- Safe and reliable: no hook and no private API, three degrade strategy.
- Easy to maintain: three layer structure and modular design.
- Fully functional: it contains H5 offline resource managing, url and offline resource mapping config, data reporting, debug tool.
Requirements
- iOS 9.0 or later
- Xcode 11.0 or later
- CocoaPods 1.11.2 or later
Get Started
- Download the code.
- Enter the 'Example' folder, enter command 'pod install' to install 3rd-party libraries.
- Open the project 'HLLOfflineWebVC.xcworkspace' and built it by Xcode. If you complile and run the demo successfully, you will see the UI below:
Communication
- If you find a bug, open an issue.
- If you have a feature request, open an issue.
- If you want to contribute, submit a pull request.
Architecture
-
OfflineWebPackage
The core module of HLLOfflineWebVC.
-
OfflineWebDevTool
An useful tool to Debug the offline web.
-
OfflineWebBisNameMatch
Connect the web page with offline resource by config.
-
OfflineWebUtils
An inner API used by other module.
How To Use
If you want to bring the code into your project, you need to do the following:
Develop A HTTP Service
-
HTTP Request
https://www.xxx.com/queryOffline?clientType=iOS&clientVer=1.0.0&offlineZipVer=1.0.0&bisName=xx
requet data parameters description:
parameter name | parameter meaning | note |
---|---|---|
clientType | operating system type | iOS,Android |
clientVersion | app version | eg: 1.0 |
bisName | unique identifier of your offline web page | eg: act3-offline-package-test |
offlineZipVer | the local offline web file version | 0 means no offline web cache |
respond data format is a json,parameters description:
parameter name | parameter meaning | note |
---|---|---|
bisName | unique identifier of your offline web page | eg: act3-offline-package-test |
result | query result | -1: disable offline web, 0: no update, 1: has new version |
url | zip file download url | if no update, the url is null |
refreshMode | notify client how to update | 0:update next(default) 1:update immediately |
version | offline web pages version | eg: 25609-j56gfa |
-
Cross Origin
When an offline web page make a network request, the origin is null,should modify your gateway or server to support.
Modify HTML And JS File
- use relative path, no absolute path.
- cookie、local storage should support the situation that host is null.
- add a file to describe the offline web version .the file name is ".offweb.json" and the content is: { "bisName": "xxx", "ver": "xxx" }
Bring The Code Into Your Client
Install Completely
Install all the modules in your project.
-
Add the string " pod 'HLLOfflineWebVC' " in your pod file.
-
Call the initial function.
- (void)initOfflineWeb {
NSDictionary *offwebConfigDict = DefaultWebPackageConfig;
[HLLOfflineWebConfig setInitalParam:offwebConfigDict
logBlock:^(HLLOfflineWebLogLevel level, NSString *keyword, NSString *message) {
NSLog (@"use your log SDK :%d:%@:%@", (int) level, keyword, message);
}
reportBlock:^(NSString *event, NSDictionary *dict) {
NSLog(@"data report:%@,%@", event, dict);
}
monitorBlock:^(HLLOfflineWebMonitorType type, NSString *key, CGFloat value, NSDictionary *lables) {
NSLog(@"use your monitor sdk ");
}
env:@"prd"
appversion:[[[NSBundle mainBundle] infoDictionary] objectForKey:@"CFBundleShortVersionString"]];
}
-
Config the dictionary.
"OffwebConfigDict" is a dictionary from json, configure the degrade strategy, auto add offweb parameters to url:
{
"switch": 1,
"predownloadlist": ["uappweb-offline"],
"disablelist": [],
"rules": [{
"host": ["test1.xxx.com", "test2.xxx.com"],
"path": ["/uapp"],
"offweb": "uappweb"
}
]
}
parameter name | parameter meaning | required or optional |
---|---|---|
switch | 1 open,0 close | required |
predownloadlist | If you need download an offline web page, add the business name | optional |
disablelist | disable some offline web page | optional |
rules | when the host and path match the rules, webview will add 'offweb=uappweb' to you url | optional |
- Modify webview container.
Implement the function bellow in your basic webview container. Then edit the parent class of HLLOfflineWebVC.
- (BOOL)webview:(WKWebView *)webview shouldStartLoadWithRequest:(NSURLRequest *)request {
return YES;
}
Declare WKWebview delegate <WKUIDelegate,WKNavigationDelegate>
in the head file.
Install Core Module
Just install the core module that not contains 'HLLOfflineWebVC', the CocoaPods command is: pod 'HLLOfflineWebVC/OfflineWebPackage' . The main API :
- Check Update API
//@param bisName: unique identifier of your offline web page
//@param resultBlock:the result block
- (void)checkUpdate:(NSString *)bisName result:(HLLOfflineWebResultBlock)resultBlock;
- Get the Local File Path of Offline Web
//@param webUrl: online web page url
//@return: the local file path of "index.html". If not exist, return nil
- (NSURL *_Nullable)getFileURL:(NSURL *)webUrl;
Author
HUOLALA mobile technology team.
License
HLLOfflineWebVC is released under the GPL license. See LICENSE for details.