fix: exclude custom elements from HTML tree validation (#13540)

fixes #13537
pull/13532/head
Simon H 4 months ago committed by GitHub
parent 6ed3ca380b
commit 06c9e5864b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -0,0 +1,5 @@
---
'svelte': patch
---
fix: exclude custom elements from HTML tree validation

@ -142,12 +142,17 @@ const disallowed_children = {
* @returns {boolean} * @returns {boolean}
*/ */
export function is_tag_valid_with_ancestor(tag, ancestors) { export function is_tag_valid_with_ancestor(tag, ancestors) {
if (tag.includes('-')) return true; // custom elements can be anything
const target = ancestors[ancestors.length - 1]; const target = ancestors[ancestors.length - 1];
const disallowed = disallowed_children[target]; const disallowed = disallowed_children[target];
if (!disallowed) return true; if (!disallowed) return true;
if ('reset_by' in disallowed && disallowed.reset_by) { if ('reset_by' in disallowed && disallowed.reset_by) {
for (let i = ancestors.length - 2; i >= 0; i--) { for (let i = ancestors.length - 2; i >= 0; i--) {
const ancestor = ancestors[i];
if (ancestor.includes('-')) return true; // custom elements can be anything
// A reset means that forbidden descendants are allowed again // A reset means that forbidden descendants are allowed again
if (disallowed.reset_by.includes(ancestors[i])) { if (disallowed.reset_by.includes(ancestors[i])) {
return true; return true;
@ -166,6 +171,8 @@ export function is_tag_valid_with_ancestor(tag, ancestors) {
* @returns {boolean} * @returns {boolean}
*/ */
export function is_tag_valid_with_parent(tag, parent_tag) { export function is_tag_valid_with_parent(tag, parent_tag) {
if (tag.includes('-') || parent_tag?.includes('-')) return true; // custom elements can be anything
if (parent_tag !== null) { if (parent_tag !== null) {
const disallowed = disallowed_children[parent_tag]; const disallowed = disallowed_children[parent_tag];

@ -3,11 +3,11 @@
"code": "node_invalid_placement", "code": "node_invalid_placement",
"message": "`<dt>` is invalid inside `<dd>`", "message": "`<dt>` is invalid inside `<dd>`",
"start": { "start": {
"line": 11, "line": 16,
"column": 3 "column": 3
}, },
"end": { "end": {
"line": 11, "line": 16,
"column": 19 "column": 19
} }
} }

@ -6,6 +6,11 @@
<dt>valid</dt> <dt>valid</dt>
<dd>valid</dd> <dd>valid</dd>
</dl> </dl>
<!-- custom element resets the validation -->
<foo-bar>
<dt>valid</dt>
<dd>valid</dd>
</foo-bar>
<!-- other tags don't --> <!-- other tags don't -->
<div> <div>
<dt>invalid</dt> <dt>invalid</dt>

@ -0,0 +1,14 @@
[
{
"code": "node_invalid_placement",
"message": "`<tbody>` is invalid inside `<div>`",
"start": {
"line": 8,
"column": 1
},
"end": {
"line": 8,
"column": 16
}
}
]

@ -0,0 +1,9 @@
<some-table>
<!-- No error -->
<tbody></tbody>
</some-table>
<div>
<!-- Error -->
<tbody></tbody>
</div>
Loading…
Cancel
Save