script-content
Validate the body of <script> elements against the spec that governs the value of its type attribute.
Currently supported content formats:
type value | Spec |
|---|---|
importmap | HTML Living Standard § Parse an import map string |
type attribute matching is ASCII case-insensitive, matching how user agents look up the script's effective MIME type.
type="importmap"
The rule reports the following issues for inline import maps:
- The element body is empty or whitespace-only
- The body cannot be parsed as JSON
- The top-level value is not a JSON object
- The top-level value contains a key other than
imports,scopes, orintegrity importsorscopesis not a JSON object- A specifier map (
imports, or a value insidescopes) contains an empty key - A specifier map address (the value side) is not a string
- A specifier map address is not a URL-like specifier (does not start with
/,./,../, and is not an absolute URL) - A specifier key ends with
/but its address does not integrityis not a JSON object- An
integritykey is not a URL-like specifier - An
integrityvalue is not a string
❌ Examples of incorrect code for this rule
<script type="importmap"></script>
<script type="importmap">
{
"forbidden": {}
}
</script>
<script type="importmap">
{
"imports": {
"dir/": "/path/to/dir"
}
}
</script>
✅ Examples of correct code for this rule
<script type="importmap">
{
"imports": {
"app": "/path/to/app.js",
"dir/": "/path/to/dir/"
},
"scopes": {
"/scope/": {
"x": "./y.js"
}
}
}
</script>
Interface
{
"script-content": boolean
}
Validate the body of <script> elements when the type attribute selects a content format that has a spec (currently: importmap).
Default Severity
error