本文主要是介绍Android Webview 大型H5 秒开方案探讨+VasSonic实现h5首页加速,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
前言
现在许多app都嵌入了H5页面, 然而WebView加载速度慢这个问题却一直影响着用户的体验, 所以本文就如何提高H5页面的加载速度展开讨论。
问题原因
首先我们需要知道为什么WebView的加载速度那么慢。H5页面的渲染速度其实主要取决于两个
- js解析效率
如果js文件较多、解析比较复杂, 就会导致渲染速度较慢。或者手机的硬件性能比较差的话, 也会导致渲染速度比较慢。 - 页面资源的下载
一般加载一个H5页面, 都会产生较多的网络请求, 如图片、js文件、css文件等, 需要将这些资源都下载完成之后才能完成渲染, 这样也会导致页面渲染速度变慢
对于上面的第一点, 其实主要是由前端代码和手机硬件决定的, 因为我们这里讨论的是对于app的性能优化, 暂时不考虑, 所以我们可以从第二点做文章, 主要思路就是一些资源文件都使用App本地资源, 而不需要从网络下载, 从而提高页面的打开速度。
方案实现
腾讯出品的一个轻量级的高性能的Hybrid框架,专注于提升页面首屏加载速度,完美支持静态直出页面和动态直出页面,兼容离线包等方案。优点是性能好, 速度快, 大厂出品, 缺点是配置复杂, 同时需要前后端接入。
首先在build.gradle导入
implementation 'com.tencent.sonic:sdk:3.1.0'
代码准备:
public class SonicRuntimeImpl extends SonicRuntime {public SonicRuntimeImpl(Context context) {super(context);}/*** 获取用户UA信息* @return*/@Overridepublic String getUserAgent() {return "Mozilla/5.0 (Linux; Android 5.1.1; Nexus 6 Build/LYZ28E) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Mobile Safari/537.36";}/*** 获取用户ID信息* @return*/@Overridepublic String getCurrentUserAccount() {return "sonic-demo-master";}@Overridepublic String getCookie(String url) {CookieManager cookieManager = CookieManager.getInstance();return cookieManager.getCookie(url);}@Overridepublic void log(String tag, int level, String message) {switch (level) {case Log.ERROR:Log.e(tag, message);break;case Log.INFO:Log.i(tag, message);break;default:Log.d(tag, message);}}@Overridepublic Object createWebResourceResponse(String mimeType, String encoding, InputStream data, Map<String, String> headers) {WebResourceResponse resourceResponse = new WebResourceResponse(mimeType, encoding, data);if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {resourceResponse.setResponseHeaders(headers);}return resourceResponse;}@Overridepublic void showToast(CharSequence text, int duration) {}@Overridepublic void notifyError(SonicSessionClient client, String url, int errorCode) {}@Overridepublic boolean isSonicUrl(String url) {return true;
这篇关于Android Webview 大型H5 秒开方案探讨+VasSonic实现h5首页加速的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!