diff options
author | Peter Bengtsson <mail@peterbe.com> | 2020-12-08 14:40:17 -0500 |
---|---|---|
committer | Peter Bengtsson <mail@peterbe.com> | 2020-12-08 14:40:17 -0500 |
commit | 33058f2b292b3a581333bdfb21b8f671898c5060 (patch) | |
tree | 51c3e392513ec574331b2d3f85c394445ea803c6 /files/zh-cn/web/api/beacon_api/index.html | |
parent | 8b66d724f7caf0157093fb09cfec8fbd0c6ad50a (diff) | |
download | translated-content-33058f2b292b3a581333bdfb21b8f671898c5060.tar.gz translated-content-33058f2b292b3a581333bdfb21b8f671898c5060.tar.bz2 translated-content-33058f2b292b3a581333bdfb21b8f671898c5060.zip |
initial commit
Diffstat (limited to 'files/zh-cn/web/api/beacon_api/index.html')
-rw-r--r-- | files/zh-cn/web/api/beacon_api/index.html | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/files/zh-cn/web/api/beacon_api/index.html b/files/zh-cn/web/api/beacon_api/index.html new file mode 100644 index 0000000000..257c31f9ed --- /dev/null +++ b/files/zh-cn/web/api/beacon_api/index.html @@ -0,0 +1,54 @@ +--- +title: Beacon API +slug: Web/API/Beacon_API +tags: + - SDK + - user behavior tracker + - user tracker + - 同步请求 + - 埋点 + - 数据分析 + - 规范 +translation_of: Web/API/Beacon_API +--- +<p>{{DefaultAPISidebar("Beacon")}}{{SeeCompatTable}}</p> + +<p><strong><code>Beacon</code></strong> 接口用于将异步和非阻塞请求发送到服务器。信标(Beacon )请求使用HTTP协议中的POST方法,请求通常不需要响应。这个请求被保证在,页面的<strong>unload</strong>状态从发起到完成之前,被发送。而并不需要一个阻塞请求,例如 {{domxref("XMLHttpRequest")}} 。</p> + +<p>Beacon API 的示例用例是记录活动并向服务器发送分析数据。</p> + +<p>本文档中描述的接口的示例代码包含在<a href="https://developer.mozilla.org/zh-CN/docs/Web/API/Beacon_API/Using_the_Beacon_API +">使用信标API</a>中。</p> + +<h2 id="为什么是信标?">为什么是信标?</h2> + +<p><code>Beacon</code> 接口满足了分析和诊断代码的需要,这些代码通常会尝试在卸载文档之前将数据发送到 web服务器。发送数据的任何过早时机都可能导致错失收集数据的机会。但是,确保在卸载文档期间发送数据是开发人员难以做到的。</p> + +<p>用户代理通常会忽略卸载文档处理程序中的异步 {{domxref("XMLHttpRequest","XMLHttpRequests")}} 请求。若要解决此问题,为了分析和诊断代码,通常会在 {{event("unload")}} 事件或 {{event("beforeunload")}} 事件中创建同步 {{domxref("XMLHttpRequest")}} 请求以提交数据。同步 {{domxref("XMLHttpRequest")}} 请求强制浏览器延迟卸载文档,并使下一个页面跳转看起来较慢。下一页面没有任何办法来避免这种页面加载性能不佳的感觉。</p> + +<p>其他技术也可以用来确保提交数据。其中一种技术是通过创建 Image 元素并在卸载文档处理程序中设置其 <code>src</code> 属性来延迟卸载以提交数据。由于大多数用户代理会延迟文档卸载,以完成挂起的图片加载,因此可以在卸载过程中提交数据。另一种方法是在卸载处理程序中创建一个无操作循环,花费数秒以延迟卸载并将数据提交到服务器。</p> + +<p>但是上述技术不仅代表了较差的编码模式,其中一些还是不可靠的,会导致下一个导航的页面加载性能较差的感觉。信标 API 提供了解决这些问题的标准方法。</p> + +<h2 id="全局环境">全局环境</h2> + +<p><code>Beacon</code> <span class="tlid-translation translation" lang="zh-CN"><span title="">API 的 </span></span> {{domxref("Navigator.sendBeacon()")}} <span class="tlid-translation translation" lang="zh-CN"><span title="">方法用于在<em>全局浏览上下文</em>中向服务器发送<em>数据信标</em>。该方法有两个参数,URL和要在请求中发送的数据data。</span><span title="">data参数是可选的,其类型可以是 </span></span>{{domxref("ArrayBufferView")}}、{{domxref("Blob")}}<span class="tlid-translation translation" lang="zh-CN"><span title="">、</span></span>{{domxref("DOMString")}} <span class="tlid-translation translation" lang="zh-CN"><span title="">或</span></span>{{domxref("FormData")}}<span class="tlid-translation translation" lang="zh-CN"><span title="">。</span><span title="">如果浏览器成功的以队列形式排列了用于传递的请求,则该方法返回“</span></span><code>true</code><span class="tlid-translation translation" lang="zh-CN"><span title="">”,否则返回“</span></span><code>false</code><span class="tlid-translation translation" lang="zh-CN"><span title="">”。</span></span></p> + +<h2 id="生产环境">生产环境</h2> + +<p><code>Beacon</code><span class="tlid-translation translation" lang="zh-CN"><span title=""> API的</span></span> {{domxref("WorkerNavigator.sendBeacon()")}} <span class="tlid-translation translation" lang="zh-CN"><span title=""> 方法用于从</span></span> <em>{{domxref("WorkerGlobalScope","worker global scope")}}</em> <span class="tlid-translation translation" lang="zh-CN"><span title="">向服务器发送<em>数据信标</em>。该方法有两个参数,URL和要在请求中发送的数据data。</span><span title="">data参数是可选的,其类型可以是</span></span> {{domxref("ArrayBufferView")}}、{{domxref("Blob")}}、{{domxref("DOMString")}} 或 {{domxref("FormData")}}<span class="tlid-translation translation" lang="zh-CN"><span title="">。如果浏览器成功的以队列形式排列了用于传递的请求,则该方法返回“</span></span><code>true</code><span class="tlid-translation translation" lang="zh-CN"><span title="">”,否则返回“</span></span><code>false</code><span class="tlid-translation translation" lang="zh-CN"><span title="">”。</span></span></p> + +<h2 id="浏览器兼容性"><span class="tlid-translation translation" lang="zh-CN"><span title="">浏览器兼容性</span></span></h2> + +<p>{{domxref("Navigator.sendBeacon","Navigator.sendBeacon()","Browser_compatibility")}}<span class="tlid-translation translation" lang="zh-CN"><span title="">表说明了该方法具有相对广泛地实现。但是,</span></span>{{domxref("WorkerNavigator.sendBeacon","WorkerNavigator.sendBeacon()","Browser_compatibility")}}<span class="tlid-translation translation" lang="zh-CN"><span title="">数据显示该方法没有被实现。</span></span></p> + +<h2 id="相关知识">相关知识</h2> + +<ul> + <li>{{domxref("WorkerGlobalScope")}}</li> + <li><a href="https://w3c.github.io/beacon/">信标标准(Beacon standard)</a></li> + <li><a href="http://caniuse.com/#search=beacon">信标 CanIUse 数据</a></li> + <li><a href="https://ehsanakhgari.org/blog/2015-04-08/intercepting-beacons-through-service-workers">通过服务程序拦截信标</a>(Intercepting beacons through service workers); Ehsan Akhgari; 2015-Apr-08</li> + <li><a href="https://webkit.org/blog/8821/link-click-analytics-and-privacy/">https://webkit.org/blog/8821/link-click-analytics-and-privacy/</a></li> + <li><a href="https://davidwalsh.name/ping-attribute">https://davidwalsh.name/ping-attribute</a></li> +</ul> |