ホームページ >ウェブフロントエンド >htmlチュートリアル >ワイヤレス パフォーマンスの最適化: ページの表示時間と非同期読み込み_html/css_WEB-ITnose
特にワイヤレス環境において、ページをできるだけ早くレンダリングし、ページをより早く表示し、白い画面時間を短縮する方法は、常にパフォーマンス最適化のトピックです。
ページは次のプロセスを経て表示されます:
layout
JSはいつでもDOMやCSSOMを変更する可能性があるため、ページ内に大量のJSがある場合、すぐに実行したい場合、ブラウザーは CSSOM のダウンロードとビルドが完了するまでダウンロードして実行します。待機している間、DOM ビルドもブロックされます。 JS が DOM と CSSDOM の構築をブロックしないように、また最初の画面の表示時間に影響を与えないように、いくつかの JS 読み込み戦略がページの表示に与える影響をテストします。
C. document.write: 過去に PC の最適化にほとんど使用されなかったスクリプト JS を非同期でロードする戦略: DEMO アドレス
function injectWrite(src){ document.write('<script src="' + src + '"></sc' + 'ript>');}
D. getScript: フォームは次のとおりです。 KISSY の内部 getScript 関数の簡単な実装: DEMO アドレス
<script> var script = document.createElement('script'); script.src = "//g.tbcdn.com/xx.js"; document.getElementsByTagName('head')[0].appendChild(script);</script>
E. 非同期属性を追加: DEMO アドレス
以下で説明する domReady は DOMContentLoaded イベントと同じです。
A (ヘッドスクリプト) | B (ボトムスクリプト) | D (getScript) | E (非同期) | F (遅延) | G (a同期する+ defer) | |||
---|---|---|---|---|---|---|---|---|
PC Chrome | ページは白くて長い、domReady:5902.545、onLoad:5931.48 | 最初にページが表示されます、domReady:5805.21、onLoad:5838.255 | 最初にページが表示されます, domReady:5917.95、onLoad:5949.30最初にページが表示されます, domReady:244.41, onLoad:5857.645 | 最初にページが表示されます, domReady:567.01, onLoad:5709.33 | 最初にページが表示されます, domReady:58 12.12、 onLoad:5845.6 | 最初にページが表示されます、 domReady:576.12 、 onLoad:5743.79 | 2 | |
ページの白い画面の長さ、 domReady:6130 、 onLoad:6268.41 | ページの白い画面の長さ、domReady: 5175.80、onLoad:5182.75 | ページの白い画面の長さ、domReady: 5617.645、onLoad:5622.115 | 502s の白い画面、その後ページに最後の変更のロード終了時間、domReady:502.71、onLoad:6032.95 | 508s が表示されます画面に続いてページには最後の変更のロード終了時間が表示されます domReady:508.95、onLoad:5538.135 | ページが白 画面の長さ、ドメイン: 5178.98、のみ: 5193.58 | 556 秒の白い画面、その後ページ表示 ロード終了時間、domream: 556、のみ: 5171.95 | ios hand Amoy webview | |
画面が長く、ページが長く、ページ 読み込みが消えます、domReady: 5291.29、onLoad: 5292.78 | ページの白い画面が長く、ページがジャンプせず、読み込みが消えます、domReady: 5123.46, onLoad: 5127.85 | ページの白い画面が長い、ページが飛ばない、読み込みが消える、domReady: 5074.86、onLoad:5079.875 | 後でdomReadyでページがすぐに見える、読み込みがすぐに消える、domReady:14.06、ロード終了:5141.735 | ページはすぐに表示され、ロードは後でdomReadyですぐに消えます、domReady:13.89、ロード終了:5157.15 | ページ ページは白くて画面が長く、ロードが最初に消えてから表示されます、domReady: 5132.395 、onLoad:5137.52 | ページはすぐに表示され、その後読み込みが消えます、domReady:13.49、読み込み終了:5124.08 | 4 | |
ページは白くなります、domReady: 5097.29、onLoad: 5100.3 7 | ページはすぐに表示され、ロード終了時間 domReady:463.33、ロード終了:5092.90 の後にページが更新されるまで 5 秒待ちます | ページがすぐに表示され、5 秒待ってから更新ロード終了時間 domReady:39.34、ロード終了: 5136.55 | ページの白い画面が長いです、domReady: 5092.45、onLoad:5119.81 | ページはすぐに表示されます、お待ちください更新読み込み終了時間domream: 50.49、読み込み終了: 5507.668 | Android hand Tao WEBVIEW | |||
ページがページに表示され、読み込みがすぐに消えます。5 秒待ってから domReady を更新します時間とロード時間 domReady:4176.34、onLoad:4209.50 | ページはすぐに表示され、ロードはすぐに消えます、domReady:6011.18、onLoad:6031.93 | ページはすぐに表示され、ロード後に消えます、5秒待ってからロード終了時間を更新しますdomReady: 36.31、読み込み終了: 5081.76 | ページがすぐに表示され、読み込み後に消える、5秒待ってから読み込み終了時間を更新する domReady: 25.11、読み込み終了: 5113.81 | ページがすぐに表示され、読み込み後に消える、待つ5秒 次に、domReady時間とロード時間を更新します domReady: 5213.11、ロード終了: 5312.19 | ページがすぐに表示され、ロードしてから消えます。5秒待ってからロード終了時間を更新します domReady: 89.67、ロード終了: 5589.95 | 从以上测试结果可以看出以下结论:
didFinishLoad 到底什么时候触发didFinishLoad 是 native 定义的事件,该事件触发时手淘 loading 菊花消失,并且 windvane 中的发出请求不再收集,也就是 native 统计出的 pageLoad 时间。在用户数据平台看到的瀑布流请求,就是在 didFinishLoad 触发前收集到的所有请求。
经过上方测试,客户端的 didFinisheLoad 事件的触发和 JS 中的 domReady(DOMContentLoaded)和 onLoad 触发没有任何关联。可能在 domReady 之前或之后,也可能在 onLoad 之前或之后。 那它到底是什么时候触发呢? iOS 官方文档 是 Sent after a web view finishes loading a frame。 结合收集的用户请求和测试,didFinishLoad 是在连续发起的请求结束之后触发,监听一段时间内无请求则触发。 所以经常会看到 data_sufei 这个 JS 文件,在有些用户的瀑布流里面有,在有些用户的又没有。原因是这个 JS 是 aplus_wap.js 故意 setTimeout 1s 后发出的,如果页面在 1s 前所有的请求都发完了则触发 didFinishLoad,后面的 data_sufei.js 的时间就不算到 pageLoad 的时间;反之如果接近 1s 页面还有图片等请求还在发,则 data_sufei.js 的时间也会被算到里面。 因此在 JS 中用 setTimeout 来延迟发送请求也有可能会影响 didFinishLoad 的时间,建议 setTimeout 的时间设置得更长一点,如 3s。 async 和 deferscript 标签上可以添加 defer 和 async 属性来优化此 script 的下载和执行。 defer :延迟HTML 4.0 规范,其作用是,告诉浏览器,等到 DOM+CSSOM 渲染完成,再执行指定脚本。
<script defer src="xx.js"></script>
下载的脚本文件在 DOMContentLoaded 事件触发前执行(即刚刚读取完\ffcfa9cf6eaa5476ca5cdb4e90c503a8标签),而且可以保证执行顺序就是它们在页面上出现的顺序。所以 添加 defer 属性后,domReady 的时间并没有提前,但它可以让页面更快显示出来。 将放在页面上方的 script 加 defer,在 PC Chrome 下其效果相当于 把这个 script 放在底部,页面会先显示。 但对 iOS Safari 和 iOS WebView 加 defer 和 script 放底部一样都是长时间白屏。 async: 异步HTML 5 规范,其作用是,使用另一个进程下载脚本,下载时不会阻塞渲染,并且下载完成后立刻执行。
<script async src="yy.js"></script>
async 属性可以保证脚本下载的同时,浏览器继续渲染。但是 async 无法保证脚本的执行顺序。哪个脚本先下载结束,就先执行那个脚本。 如何选择 async 和 defer
|