本文为您列出了边缘程序ER(EdgeRoutine)的waitUntil相关的常见问题。
为什么Fetch请求有时能完成,有时不能完成?
Fetch请求有时能完成,有时不能完成的原因如下:
受生命周期限制
当您调用
addEventListener
注册事件回调函数时,会自动创建上下文。当您的主回复结束,即调用event.respondWith
返回的Response对象被读取完毕(包括header、body)后会结束上下文。所有异步函数的生命周期都在上下文生命周期之内,您在回调函数中await的Promise会阻塞当前的回调函数,直到该Promise被resolve。如果您不想await,则可以使用event.waitUntil函数,该函数会延长上下文的生命周期,直到所有被waitUntil的Promise执行完毕。
受共享状态影响
多个上下文之间不能共享状态,任何非JS标准的数据结构都不支持跨上下文共享,例如Service Worker API的数据结构、Stream对象。当上下文A使用非上下文A的对象时,会被ER检测出来并抛出异常。
说明您可以使用JS的原生对象共享状态,例如String、Array、Object和数字等,您自己编写的Class也可以用于共享状态。
受并发影响
所有没有被await的Promise都是并发的,如果您希望ER程序能立即回复浏览器,可以不await子请求,直接使用waitUntil保证程序正常执行。
受异步错误影响
如果waitUntil中的子请求有一个出错,整个上下文会被立刻退出。
waitUntil可以调用多次吗?
waitUntil可以调用多次,也可以嵌套waitUntil,即一个waitUntil的Promise被resolve,其回调函数中继续调用waitUntil。
说明
上下文有时间限制,超过时间的上下文会被强制退出。
文档内容是否对您有帮助?