Join the AI Workshop and learn to build real-world apps with AI. A hands-on, practical program to level up your skills.
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 class was not included in 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: grid-cols-1 grid-cols-2 grid-cols-3 */
<div className={`grid grid-cols-${data[0].length}`}>
In Tailwind v4 you can also safelist classes directly in CSS using @source inline():
@import "tailwindcss";
@source inline("text-green-500 text-blue-500 text-red-500");
This guarantees those classes are generated even if they do not appear in your HTML or JS files.