Tony Sullivan

Class properties in Svelte

Navillus.dev

tony @ navillus .dev

2 min read

A handy trick to make your Svelte components feel even more like plain old HTML.

I’ve noticed an interesting pattern when a React developer gives Svelte a try - they almost immediately add a className property to their first Svelte component.

Don’t get me wrong, the power of dynamically adding classes to a component can save your butt. The term className is a dodge in the JSX world though since class is a reserved word in JavaScript. Here’s a quick trick to make your Svelte components feel even more like plain old HTML with a proper class property!

tl;dr; Check out the REPL example to see a working example.

First, the problem

With Svelte, you may think it’s as simple as

<script>
  export let class = "";
</script>

<div {class}>...</div>

Unfortunately you run smack into the same reserved word problem - Svelte treats the script as regular JavaSript (or TypeScript) and won’t allow a variable named class.

The workaround

If you’re like me you probably hit this once, banged your head against the nearest wall a couple times, then moved on to the obvious fix of renaming the prop to class.

<script>
  export let className = ''
</script>

<div class="{className}">...</div>

Writing Svelte is so close to HTML that you can almost forget there’s a framework at all…until you come across something like <Button className="send-btn"/>. Those four extra characters stand out like a sour thumb, flashing a big neon sign to remind you this isn’t actually HTML.

There’s an easy fix

<script>
  let className = ''
  export { className as class }
</script>

<div class="{className}">...</div>

That’s all there is to it! Internally the property is named className, avoiding JavaScript’s reserved word issue. Externally, though, the component has an optional property named class.

<button class="send-btn" />

Doesn’t that just feel right? No more JSX-like className property screaming “is this React!?!”

Conclusion

React is a very powerful framework and web development wouldn’t be where it is today without it. But when it comes to workarounds like renaming class to className, or camel casing CSS properties for that matter, it can feel freeing when you can move past those quirks and get back to the basics.