prevent bind:offsetWidth etc on void elements

pull/1386/head
Rich Harris 7 years ago
parent fe4637305b
commit 4a67542bec

@ -3,6 +3,7 @@ import validateEventHandler from './validateEventHandler';
import validate, { Validator } from '../index'; import validate, { Validator } from '../index';
import { Node } from '../../interfaces'; import { Node } from '../../interfaces';
import { dimensions } from '../../utils/patterns'; import { dimensions } from '../../utils/patterns';
import isVoidElementName from '../../utils/isVoidElementName';
const svg = /^(?:altGlyph|altGlyphDef|altGlyphItem|animate|animateColor|animateMotion|animateTransform|circle|clipPath|color-profile|cursor|defs|desc|discard|ellipse|feBlend|feColorMatrix|feComponentTransfer|feComposite|feConvolveMatrix|feDiffuseLighting|feDisplacementMap|feDistantLight|feDropShadow|feFlood|feFuncA|feFuncB|feFuncG|feFuncR|feGaussianBlur|feImage|feMerge|feMergeNode|feMorphology|feOffset|fePointLight|feSpecularLighting|feSpotLight|feTile|feTurbulence|filter|font|font-face|font-face-format|font-face-name|font-face-src|font-face-uri|foreignObject|g|glyph|glyphRef|hatch|hatchpath|hkern|image|line|linearGradient|marker|mask|mesh|meshgradient|meshpatch|meshrow|metadata|missing-glyph|mpath|path|pattern|polygon|polyline|radialGradient|rect|set|solidcolor|stop|switch|symbol|text|textPath|tref|tspan|unknown|use|view|vkern)$/; const svg = /^(?:altGlyph|altGlyphDef|altGlyphItem|animate|animateColor|animateMotion|animateTransform|circle|clipPath|color-profile|cursor|defs|desc|discard|ellipse|feBlend|feColorMatrix|feComponentTransfer|feComposite|feConvolveMatrix|feDiffuseLighting|feDisplacementMap|feDistantLight|feDropShadow|feFlood|feFuncA|feFuncB|feFuncG|feFuncR|feGaussianBlur|feImage|feMerge|feMergeNode|feMorphology|feOffset|fePointLight|feSpecularLighting|feSpotLight|feTile|feTurbulence|filter|font|font-face|font-face-format|font-face-name|font-face-src|font-face-uri|foreignObject|g|glyph|glyphRef|hatch|hatchpath|hkern|image|line|linearGradient|marker|mask|mesh|meshgradient|meshpatch|meshrow|metadata|missing-glyph|mpath|path|pattern|polygon|polyline|radialGradient|rect|set|solidcolor|stop|switch|symbol|text|textPath|tref|tspan|unknown|use|view|vkern)$/;
@ -169,6 +170,11 @@ export default function validateElement(
code: 'invalid-binding', code: 'invalid-binding',
message: `'${attribute.name}' is not a valid binding on SVG elements` message: `'${attribute.name}' is not a valid binding on SVG elements`
}); });
} else if (isVoidElementName(node.name)) {
validator.error(attribute, {
code: 'invalid-binding',
message: `'${attribute.name}' is not a valid binding on void elements like <${node.name}>. Use a wrapper element instead`
});
} }
} else { } else {
validator.error(attribute, { validator.error(attribute, {

@ -0,0 +1,15 @@
[{
"code": "invalid-binding",
"message": "'offsetWidth' is not a valid binding on void elements like <img>. Use a wrapper element instead",
"pos": 22,
"start": {
"line": 1,
"column": 22,
"character": 22
},
"end": {
"line": 1,
"column": 38,
"character": 38
}
}]

@ -0,0 +1 @@
<img src='potato.jpg' bind:offsetWidth>
Loading…
Cancel
Save