Android客户?混搭HTML页面,会出现虽然HTML内?载入完成,标题也正常显示,但??页需要等到近5秒(甚至更?)时间才会显示出来?研究了很久,搜遍了国?很?网站,也看过PhoneGap的代码,?直无解??/p>
??堆WebView的加速,都是建?先用 webView.getSettings().setBlockNetworkImage(true); 将图片下载阻塞,然后在浏览器的OnPageFinished事件???webView.getSettings().setBlockNetworkImage(false); 通过图片的延迟载入,让网页能更快地显示??/p>
但是,?过实际的日志发现,Android的OnPageFinished事件会在Javascript脚本执?完成之后才会触发。?果在页面? 用JQuery,会在?理完DOM对象,执行完$(document).ready(function() {});事件?后才会渲染并显示页面。?下图
?看到在载入完?后一个JS脚本之后,?DOM元素的渲染和处理就花?秒,然后执?了AJAX方法载入外部页面又花??秒,?后才会触?onPageFinished显示页面。再?后由于程序中设置了setBlockNetworkImage(false),所以开始载入?部图片?(如果 不控制这?数,图片载入会在渲染期间下载? 综上,由于JS脚本的?理,造成了一张页面打?多花?0秒左右时间??同样的页面在iPhone上却?入相当的?显示完页面才会触发脚??行?(提示:?果使用JQueryMobile,更会慢得?谱)
要解决这?题,就是想办法?浏?器延迟加载JS脚本,但是Android的WebView控件没有这样的参数?无法单?塞JS脚本,另外有个setBlockNetworkLoads,用了之后也无法实现类似图片的异步载入的功能,页面成了光板,连CSS也阻塞了?/p>
就是这个??困扰了很久,直到在做HTML照片墙时,由于setBlockNetworkImage在OnPageFinished之后才会释放?导致在JS脚本载入图片过程?法获取图片的高?信息,最后巧妙地通过$(document).ready(function() {setTimeout(func,10)});,成功将函数在onPageFinished之后运?。那么延伸来想,??将JS脚本也用同样的方?延迟载入?
答??定的,在 http://wonko.com/post/painless_javascript_lazy_loading_with_lazyload ?找到JS脚本延迟加载的?三方组件?/p>
我改造了之前速度奇慢的界?我所使用的核心JS代码如下?/p>
<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之后执??/p>
?终执行的效果如图?/p>
?看到非常显著的改善,从onPageStarted到onPageFinished??秒不到的时间,这?间主要花在HTML和CSS?染上。从界面上来看,就是???过的网页载入进度条,立即显示CSS渲染过的页面效果,然后再载入并执行JS脚本,?块显示?要?过AJAX获取的数???/p>
综上,解决Android载入WebView页面慢的??,不是Android程序员的事情,?是Web前?工程师的??。?果您使用基于WebView的Android?方壳工具(例如PhoneGap,可以?过这?方式改善UI界面的响应时间)?/p>
发布这个解决方?,希望基于Web的?户?解决方?能更上一层楼,?HTML和原生App混搭或的纯WebApp实现效果?更理?/p>