@dimaslz/react-dynamic-classname
TypeScript icon, indicating that this package has built-in type declarations

0.0.3 • Public • Published

@dimaslz/react-dynamic-classname

React component to have a flexible className as Vue style but in React.

Motivation

I like to create tools and small libraries and, this was an excuse to create a library in React. Other motivatin is, under my experience, as I have worked with Vue with dynamic classes, has a better flexibility to work with directly in the template and, it is something that I do when I work in React and I have to apply some conditionals in the className.

To clarify: I do saying that is better, just is a different way. For me sometimes it is useful.

Installation

npm: npm install @dimaslz/react-dynamic-classname

yarn: yarn add @dimaslz/react-dynamic-classname

Example

Pure React

// ...

export const App = () => {
	return (
		<TAG className={
			conditionTrue ? "class-a": "",
			conditionFalse ? "class-b": "",
			conditionTrue ? "class-c": "",
		}>
			Demo text
		</TAG>
	)
}

export default App
<!-- will be rendered as: -->
<TAG class="class-a class-c">
	Demo text
</TAG>

With this component

import { ReactDynamicClass } from '@dimaslz/react-dynamic-classname';

export const App = () => {
	return (
		<ReactDynamicClassName>
			// ...
			<TAG d-classname={{
				"class-a": true,
				"class-b": false,
				"class-c": true
			}}>
				Demo text
			</TAG>
			// ...
		</ReactDynamicClassName>
	)
}

export default App
<!-- will be rendered as: -->
<TAG class="class-a class-c">
	Demo text
</TAG>

Live demo: https://react-dynamic-classname.dimaslz.dev

Author

{
	name: "Dimas López",
	role: "FullStack Software development",
	alias: "dimaslz",
	twitter: "https://twitter.com/dimaslz",
	site: "https://dimaslz.dev",
	linkedin: "https://www.linkedin.com/in/dimaslopezzurita"
}

Package Sidebar

Install

npm i @dimaslz/react-dynamic-classname

Weekly Downloads

1

Version

0.0.3

License

MIT

Unpacked Size

20.3 kB

Total Files

25

Last publish

Collaborators

  • dimaslz