解決方案
將分析數據發送到服務器,因為文檔卸載可能看起來像這樣:
>卸載事件處理程序,該處理程序通過AJAX請求提交數據。當頁面卸載事件啟動時,數據將通過caureanalyticsdata函數捕獲,並通過AJAX請求發送到服務器。請注意Xhr.open的第三個參數是錯誤的,表明AJAX請求為
>都具有同步性。由於它是同步的,因此瀏覽器必須等待請求在>之前完成>它可以卸載文檔並顯示下一頁。等待的額外等待可能會導致表現不佳的感覺。
<span>window.addEventListener('unload', function(event) { </span> <span>var xhr = new XMLHttpRequest(), </span> data <span>= captureAnalyticsData(event); </span> xhr<span>.open('post', '/log', false); </span> xhr<span>.send(data); </span><span>}); </span> <span>function captureAnalyticsData(event) { </span> <span>return 'sample data'; </span><span>}</span>>使用的其他技術代替同步AJAX請求包括在卸載處理程序中設置圖像對象的SRC。瀏覽器將在卸載文檔之前等待圖像加載,在此期間可以將數據提交給服務器。但是,這仍然存在相同的問題:當前文檔的卸載將在請求,這次完成圖像完成時延遲,這可能會導致性能差。
創建了Beacon API,以幫助解決這些問題。它定義了一個接口,該接口使開發人員可以將少量數據發送到Web服務器異步。它僅包含一種連接到導航對象的方法,即sendbeacon。 SendBeacon採用兩個參數,您要提交數據的URL以及要提交的數據:
<span>window.addEventListener('unload', function(event) { </span> <span>var xhr = new XMLHttpRequest(), </span> data <span>= captureAnalyticsData(event); </span> xhr<span>.open('post', '/log', false); </span> xhr<span>.send(data); </span><span>}); </span> <span>function captureAnalyticsData(event) { </span> <span>return 'sample data'; </span><span>}</span>> Navigator.SendBeacon在主要桌面瀏覽器中都不錯。您會發現它在當前版本的Chrome,Firefox和Opera中得到了支持,但在IE和Safari的最新版本中不支持它。但是,您不能保證它的可用性,最好的選擇是使用功能檢測和後備到頁面上提交數據的舊方法之一:
>
>我創建了一個小示例應用程序,您可以使用該應用程序來查看Beacon API的作用。您需要安裝node.js來運行服務器。運行樣本:
<span>window.addEventListener('unload', function(event) { </span> <span>var data = captureAnalyticsData(event); </span> <span>navigator.sendBeacon('/log', data); </span><span>});</span>
>下載並將zip文件解壓縮到您選擇的文件夾中,例如BeaConapi
在此示例中,我們使用的是Chrome。打開開發工具,切換到網絡選項卡,然後勾選“保存日誌”複選框。過濾結果,以便您只看到其他請求。現在,當您單擊“卸載”按鈕時,您應該在Dev Tools中查看請求 /日誌記錄。
結論
>我如何在Web應用程序中使用Beacon API?要在Web應用程序中使用信標API,可以使用Navigator.sendBeacon()方法。此方法需要兩個參數:將數據發送到的URL以及發送的數據。數據可以是formdata對象,blob,arraybufferview或urlsearchparams對象。這是一個示例:
>
> Beacon Api處理失敗如何?信標API沒有提供有關服務器是否成功收到數據的任何反饋。如果由於網絡問題而無法發送數據,則API不會重試發送數據。這就是為什麼建議將信標API用於不需要確認收據的非關鍵數據的原因。
>是否在所有瀏覽器中支持的信標API? Beacon API在大多數現代瀏覽器中都得到支持,包括Chrome,Firefox,Safari和Edge。但是,Internet Explorer不支持它。您可以在網站上檢查當前的瀏覽器支持。例如分析數據。儘管您可以發送的數據量沒有嚴格的限制,但是發送大量數據可能會影響用戶網絡性能。因此,建議使用信標API發送少量的非關鍵數據。
>>
以上是信標API簡介的詳細內容。更多資訊請關注PHP中文網其他相關文章!