Bug 203073

Summary: Inline stylesheet with a non-standard media attribute value is not parsed
Product: WebKit Reporter: Jouni Koivuviita <jouni>
Component: CSSAssignee: Nobody <webkit-unassigned>
Status: RESOLVED CONFIGURATION CHANGED    
Severity: Normal CC: ahmad.saleem792, koivisto, rniwa, simon.fraser, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: Safari 13   
Hardware: Mac   
OS: macOS 10.15   

Jouni Koivuviita
Reported 2019-10-17 00:25:51 PDT
The following code works in Chrome and Firefox – a CSSStyleSheet object is printed in the console. In Safari, undefined is printed. <style media="foobar"> foo { color: red; } </style> <script> console.log(document.styleSheets[0]); </script> Using a non-standard media value for the <link> element or for an @import statement works the same in all three browsers, and document.styleSheets contains the parsed stylesheet(s). <link rel="stylesheet" href="some-stylesheet.css" media="foobar"> <style> @import "some-stylesheet.css" foobar; </style>
Attachments
Alexey Proskuryakov
Comment 1 2019-10-19 12:45:02 PDT
I understand that this is a difference in behavior with other browsers. But it's not obvious if this is something that needs to be fixed, as unsupported media values seem useless. What is the use case for which you need to do this?
Radar WebKit Bug Importer
Comment 2 2019-10-19 12:45:15 PDT
Jouni Koivuviita
Comment 3 2019-10-20 22:52:31 PDT
Yeah, they seem quite useless. But the side-effect of an unsupported media query is that it makes the styles inert for the document/shadowRoot, yet they are still parsed and accessible through the DOM. That makes them interesting to me. My use case is a workaround to the lack of sufficient native styling APIs for web components (shadow DOM). I’ve written about it more here: https://v0-4--jelements.netlify.com/util/stylable Basically, if I have a custom element <my-component> with a shadow root, I would be able to write styles for it like so: @media my-component { .some-class-inside-the-shadow-dom { ... } } To me, the spec seems a quite clear how the values should be handled, when speaking of values that start the media query (”media type”). https://drafts.csswg.org/mediaqueries-3/#background > Future versions of HTML may introduce new values and may allow parameterized values. To facilitate the introduction of these extensions, conforming user agents must be able to parse the media attribute value as follows: > > The value is a comma-separated list of entries. For example, > media="screen, 3d-glasses, print and resolution > 90dpi" > > is mapped to: > "screen" > "3d-glasses" > "print and resolution > 90dpi" > > Each entry is truncated just before the first character that isn't a US ASCII letter [a-zA-Z] (Unicode decimal 65-90, 97-122), digit [0-9] (Unicode hex 30-39), or hyphen (45). In the example, this gives: > "screen" > "3d-glasses" > "print"
Ahmad Saleem
Comment 4 2022-08-06 18:18:44 PDT
I am unable to reproduce this bug in Safari 15.6 on macOS 12.5 using test case from Comment 0 and changed into below JSFiddle: Link - https://jsfiddle.net/hab9pgeu/show I am getting "CSSStyleSheet" value in Console on Safari as below: _________ CSSStyleSheet cssRules: CSSRuleList {0: CSSStyleRule, length: 1, item: function} disabled: false href: "https://fiddle.jshell.net/css/result-light.css" media: MediaList {mediaText: "", length: 0, item: function, deleteMedium: function, appendMedium: function, …} ownerNode: <link> ownerRule: null parentStyleSheet: null rules: CSSRuleList {0: CSSStyleRule, length: 1, item: function} title: null type: "text/css" _____ I think we can mark this as "RESOLVED CONFIGURATION CHANGED" since it is fixed now.
Jouni Koivuviita
Comment 5 2022-08-08 00:28:03 PDT
Yes, looks like it is working now. Although, the JSFiddle test is logging a different style sheet. There are three style sheets on that page, and it’s the third one that has the non-standard media attribute value (document.styleSheets[2]).
Note You need to log in before you can comment on or make changes to this bug.