我正在尝试使用以下代码通过 CloudFlare Workers 实现 HTTP/2 服务器推送:
let mainScript='main-es2015.e66dc0bc532401d980dc.js';
response.headers.append("Link", "</"+mainScript+">; rel=preload; as=script;");
我也尝试过添加跨域
response.headers.append("Link", "</"+mainScript+">; rel=preload; as=script; crossorigin;");
但它不起作用。
在第一种情况下,开发人员控制台确实显示文件正在从 CloudFlare 服务器推送以及 html 响应。但浏览器不使用该文件并重复请求再次下载该文件。
在第二种情况下,开发者控制台显示浏览器确实尊重预加载的标头,但文件的内容不是从 Cloudflare 服务器推送的,浏览器必须单独请求拉取 javascript 文件,尽管它在收到后立即发出请求html文件。
我想要的是 cloudflare 服务器推送文件和浏览器以使用该推送文件而不发出重复请求?
令人惊讶的是,下面的代码非常适用于 css 文件:
response.headers.append("Link", "</styles.1d228f78d240e617dd5e.css>; rel=preload; as=style;");
但不适用于任何其他内容,如 javascript 字体文件、图像等。
谁能指导我在这里缺少什么?