[Android分享] ANDROID的WEBVIEW控件载入网页显示速度慢的究极解决方案

本文探讨了在Android客户端中混搭HTML页面时遇到的加载速度问题,并分享了一个有效的解决方案,通过延迟加载JS脚本和使用第三方组件,显著提高了WebView页面的加载速度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

帮大家转载一篇关于优化webview页面加载速度的文章,在这里感谢原作者付出的努力,希望对大家有所帮助哈。
【转自http://hi.baidu.com/goldchocobo/】
Android客户端中混搭HTML页面,会出现虽然HTML内容载入完成,标题也正常显示,但是整个网页需要等到近5秒(甚至更多)时间才会显示出来。研究了很久,搜遍了国外很多网站,也看过PhoneGap的代码,一直无解。

一般人堆WebView的加速,都是建议先用webView.getSettings().setBlockNetworkImage(true); 将图片下载阻塞,然后在浏览器的OnPageFinished事件中设置webView.getSettings().setBlockNetworkImage(false); 通过图片的延迟载入,让网页能更快地显示。

但是,通过实际的日志发现,Android的OnPageFinished事件会在Javascript脚本执行完成之后才会触发。如果在页面中使用JQuery,会在处理完DOM对象,执行完$(document).ready(function() {});事件自会后才会渲染并显示页面。如下图



可以看到在载入完最后一个JS脚本之后,对DOM元素的渲染和处理就花了8秒,然后执行了AJAX方法载入外部页面又花了2、3秒,最后才会触发onPageFinished显示页面。再往后由于程序中设置了setBlockNetworkImage(false),所以开始载入外部图片。(如果不控制这个参数,图片载入会在渲染期间下载。  综上,由于JS脚本的处理,造成了一张页面打开多花了10秒左右时间。而同样的页面在iPhone上却是载入相当的快,显示完页面才会触发脚本的执行。(提示:如果使用JQueryMobile,更会慢得离谱)

要解决这个问题,就是想办法让浏览器延迟加载JS脚本,但是Android的WebView控件没有这样的参数。无法单独阻塞JS脚本,另外有个setBlockNetworkLoads,用了之后也无法实现类似图片的异步载入的功能,页面成了光板,连CSS也阻塞了。

就是这个问题困扰了很久,直到在做HTML照片墙时,由于setBlockNetworkImage在OnPageFinished之后才会释放,导致在JS脚本载入图片过程中无法获取图片的高宽信息,最后巧妙地通过$(document).ready(function() {setTimeout(func,10)});,成功将函数在onPageFinished之后运行。那么延伸来想,是否可以将JS脚本也用同样的方式延迟载入呢?

答案是肯定的,在 http://wonko.com/post/painless_javascript_lazy_loading_with_lazyload 可以找到JS脚本延迟加载的第三方组件。

我改造了之前速度奇慢的界面,我所使用的核心JS代码如下:

<script src="/css/j/lazyload-min.js" type="text/javascript"></script>
<script type="text/javascript" charset="utf-8">
  loadComplete() {
    //instead of document.read();
  } 
  function loadscript() {
    LazyLoad.loadOnce([
      '/css/j/jquery-1.6.2.min.js',
      '/css/j/flow/jquery.flow.1.1.min.js',
      '/css/j/min.js?v=2011100852'
      ], loadComplete);
  }
  setTimeout(loadscript,10);
</script>

就是混搭setTimeout和layzload,让JS脚本可以真正在onPageFinish之后执行。

最终执行的效果如图:



可以看到非常显著的改善,从onPageStarted到onPageFinished只用了2秒不到的时间,这个时间主要花在HTML和CSS渲染上。从界面上来看,就是一闪而过的网页载入进度条,立即显示CSS渲染过的页面效果,然后再载入并执行JS脚本,逐块显示需要通过AJAX获取的数据。

综上,解决Android载入WebView页面慢的问题,不是Android程序员的事情,而是Web前端工程师的问题。如果您使用基于WebView的Android第三方壳工具(例如PhoneGap,可以通过这种方式改善UI界面的响应时间)。

发布这个解决方案,希望基于Web的客户端解决方案能更上一层楼,让HTML和原生App混搭或的纯WebApp实现效果可以更理想,功德无量......
### 使用 Kivy 中的 WebView 组件加载网页 Kivy本身并不直接提供名为`WebView`的组件,但是可以通过Python代码调用平台特定的功能来实现相同的效果。对于Android设备而言,可以利用Pyjnius库与底层API交互从而嵌入WebView[^1]。 为了在基于Kivy的应用程序里显示Web页面,在安卓平台上通常会采用如下方式: #### 安卓上的解决方案 通过 `plyer` 或者更底层的方式即借助 Pyjnius 来访问 Android 的原生控件。下面是一个简单的例子展示怎样创建一个包含WebView的小部件并加载指定URL: ```python from kivy.uix.boxlayout import BoxLayout from kivy.base import runTouchApp from jnius import autoclass, cast # 加载必要的 Java 类 Intent = autoclass('android.content.Intent') Uri = autoclass('android.net.Uri') # 创建布局容器 class MyBrowser(BoxLayout): def __init__(self, **kwargs): super(MyBrowser, self).__init__(**kwargs) PythonActivity = autoclass('org.kivy.android.PythonActivity').mActivity # 初始化 WebView 设置 WebView = autoclass('android.webkit.WebView') webView = WebView(PythonActivity) settings = webView.getSettings() settings.setJavaScriptEnabled(True) # 启用 JavaScript 支持 [^2] # 将 WebView 添加到当前活动窗口中 activity = PythonActivity mainLayout = activity.findViewById( autoclass('android.R$id').content) mainLayout.addView(webView) # 载入目标网址 urlToLoad = 'http://www.example.com' webView.loadUrl(urlToLoad) if __name__ == '__main__': runTouchApp(MyBrowser()) ``` 这段脚本展示了如何设置WebView以支持JavaScript,并将其添加至应用程序界面内,同时指定了要打开的具体网站地址。 需要注意的是上述方法适用于构建针对Android系统的应用;如果考虑跨平台开发,则可能需要寻找其他适合iOS或其他操作系统的替代方案,比如使用CEF(Chromium Embedded Framework)作为备选技术之一[^3]。 当涉及到全屏模式的支持时,如播放视频等内容,还需要额外处理一些事件监听器以及视图管理逻辑,确保用户体验良好[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值