-
Notifications
You must be signed in to change notification settings - Fork 35
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Consider extending <link>
and Selectors
#307
Comments
I stared at your relatively simple example ( And I'm very familiar with speculation rules! JSON allows easier formatting in therefore understanding and/or spotting errors. I find the original example that was based upon much easier to grok: {
"prerender": [
{"where": {"and": [
{"href_matches": "/*"},
{"not": {"href_matches": "/logout"}},
{"not": {"selector_matches": ".no-prerender"}}
]}}
]
} Now tooling could of course translate between the two but if needing to do that all the time, then maybe that's the better format. |
I took the It's possible to do linebreaks and indentation within the selector to make it easier to read: <link rel="nav-prerender" selector="
:link-href('/*'):not(
:link-href('/logout'),
.no-prerender
)"> |
Ah gotcha. Slightly different example but close enough to the one in the explainer you linked to cause me confusion! 😀 |
Thanks for filing this! I think this is the unfortunate result of having to guess at others' feedback. When we started requesting wide review for this project over two years ago, the team had similar discussions and questions. In the absence of feedback, we had to guess: which path would be most palatable to the web developer community and to other implementers? At the time, I argued that other vendors generally did not like inventing new microsyntaxes, and would not like repurposing an element like It seems like, at least in Mozilla's case, my arguments were incorrect, and so we guessed wrong. Where do we go from here? At this point we have almost 4% of page loads using this feature, from many origins. And so far over the two years of shipping this feature we haven't heard any web developer complaints about the use of JSON over HTML. Still, your proposed syntax seems pretty reasonable. We'd be willing to consider implementing it in Chromium if you're able to find evidence that doing so would significantly move developer sentiment, or if doing so would bring us into interoperability with Mozilla's implementation. It's also possible that some subsets of it would be more exciting to developers than others, e.g. maybe the CSSWG would be a receptive to your proposal for a
We've explored this, in reaction to the TAG feedback which suggested that simple solutions would be appreciated. Somewhat surprisingly, all the developers we talked to so far were lukewarm about this, and none said they would use it on their sites. The general sentiment was that the full power of speculation rules was necessary for many of their use cases, and that introducing something new that only worked for very simple cases would confuse the landscape and be hard to teach. We still kind of like it as an idea, but without any developer interest we've currently put it on hold.
We built this for some significant cases where platforms (e.g. CMSes or CDNs) wanted to inject speculation rules without modifying the HTML they were serving. I think that wanting to inject such speed optimizations is generally more common than wanting to inject other HTML metadata. It's possible we could do this by putting the speculation rules themselves into a HTTP header, instead of using a link to an external file containing the speculation rules. (Either in JSON format, or in some sort of structured-header format, or maybe some extension of the It's also the case that, unlike |
We're retracting this proposal, since website adoption has happened and any additions would strictly increase complexity.
I agree we wouldn't want to make
The lack of complaints is compelling.
I think at this point, it's too late and adding an attribute-based alternative would increase complexity. I ran a query of 1% of httparchive.response_bodies to get a sense of how common it is to use a single URL or a list of URLs vs more a complex rule. It looks like there's a mix of both for inline speculation rules. https://docs.google.com/spreadsheets/d/1yBREt-aUB_4RxHlpsW4CbjtRuecBSJ81Ca8zTEdoozg/edit?usp=sharing
OK.
Having it in an external file seems reasonable. Out of curiosity, I did a query of the 10k sample of httparchive for response headers, and a python script to fetch those URLs to see what these rules look like. 104 pages (~1%) had the header in the November dataset, but only 1 of those had a non-empty ruleset. Loading a few of the pages in Chrome and checking the Network tab in devtools, it looks like the pages no longer have a https://docs.google.com/spreadsheets/d/1GFxjSjCWkFsskaxOInvs0DVj-GZziccQoEB9ZufDJXc/edit?usp=sharing |
FYI to save your Big Query usage in future we capture the HTML speculation rules in the performance custom metrics: https://github.com/HTTPArchive/custom-metrics/pull/109/files. No HTTP Header rules in there though (we should add!). Also #348 is relevant here. |
From mozilla/standards-positions#620 (comment)
We (Mozilla) struggle a lot with the JSON syntax and the introduction of a new query language. We have Selectors, and it seems possible to add URL patterns to Selectors.
Furthermore, the rebuttals for
<link>
in the explainer can be solved without jumping to JSON syntax. The explainer even says that new rel values are possible. Since "prefetch" was changed to a subresource prefetch, now the terminology is confusing even with speculation rules vs link rel. Why not usenav-prerender
andnav-prefetch
as new rel values? And make them work on<a>
also, to enable prerendering or prefetching a specific link, where all of the existing attributes can apply (liketarget
,referrerpolicy
, etc)? Listing multiple URLs can be a new space-separated or comma-separated attribute (like srcset).Example:
The motivation for external speculation rules is "it would be convenient", but that could apply to any HTML metadata? Is it necessary to support external rules?
The text was updated successfully, but these errors were encountered: