files/en-us/web/svg/reference/element/switch/index.md
The <switch> SVG element evaluates any {{SVGAttr("requiredFeatures")}}, {{SVGAttr("requiredExtensions")}} and {{SVGAttr("systemLanguage")}} attributes on its direct child elements in order, and then renders the first child where these attributes evaluate to true.
Other direct children will be bypassed and therefore not rendered. If a child element is a container element, like {{SVGElement("g")}}, then its subtree is also processed/rendered or bypassed/not rendered.
[!NOTE] The
displayandvisibilityproperties have no effect on<switch>element processing. In particular, settingdisplay:noneon a child has no effect on the true/false testing for<switch>processing.
{{svginfo}}
{{SVGAttr("requiredExtensions")}}
{{SVGAttr("systemLanguage")}}
This element implements the {{domxref("SVGSwitchElement")}} interface.
This example demonstrates showing different text content depending on the browser's language settings. The <switch> element will display the first of its child elements whose {{SVGAttr("systemLanguage")}} attribute matches the user's language, or the fallback element with no systemLanguage attribute if none of them match.
<svg viewBox="0 -20 100 50">
<switch>
<text systemLanguage="ar">مرحبا</text>
<text systemLanguage="de,nl">Hallo!</text>
<text systemLanguage="en-us">Howdy!</text>
<text systemLanguage="en-gb">Wotcha!</text>
<text systemLanguage="en-au">G'day!</text>
<text systemLanguage="en">Hello!</text>
<text systemLanguage="es">Hola!</text>
<text systemLanguage="fr">Bonjour!</text>
<text systemLanguage="ja">こんにちは</text>
<text systemLanguage="ru">Привет!</text>
<text requiredExtensions="http://example.org/lang/ext/emoji">☺</text>
</switch>
</svg>
{{ EmbedLiveSample('examples') }}
{{Specifications}}
{{Compat}}