You can’t generate classes dynamically in Tailwind
New Courses Coming Soon
Join the waiting lists
I wanted to have a dynamic color in Tailwind, using a syntax like this in JSX:
bg-${color}-500
But it wasn’t applied to the page because Tailwind couldn’t find for example the text bg-red-500
in the code, so the code was not added to the final CSS.
So instead I made a list of possible color options in a switch, and generated the class:
const getColorClass = (color) => {
switch (color) {
case 'green': return 'text-green-500'
case 'blue': return 'text-blue-500'
case 'red': return 'text-red-500'
default: return ''
}
}
And I used this function in my classes:
<h1 className={`mt-10 ${getColorClass(color)}`}>
...
A “quick way” is to write the classes you might need in a comment, like this:
/* possible Grid values are grid-cols-1 grid-cols-2 grid-cols-3 */
<div className={`grid grid-cols-${data[0].length}`}>
→ Get my CSS Handbook
→ Read my CSS Tutorial on
The Valley of Code
Here is how can I help you:
- COURSES where I teach everything I know
- CODING BOOTCAMP cohort course - next edition in 2025
- THE VALLEY OF CODE your web development manual
- BOOKS 17 coding ebooks you can download for free on JS Python C PHP and lots more
- Interesting links collection
- Follow me on X