首页IT科技react动态添加tab(React通过classnames库添加类)

react动态添加tab(React通过classnames库添加类)

时间2025-09-10 20:47:07分类IT科技浏览6138
导读:React添加Class的方式...

React添加Class的方式

在vue中添加class是一件非常简单的事情:

你可以通过传入一个对象, 通过布尔值决定是否添加类:

<button :class="{ active: isFlag, aaa: true}">按钮</button>

你也可以传入一个数组:

<!-- 1.基本使用 --> <h2 :class="[aaa, bbb]">Hello Vue</h2> <!-- 2.数组中存放变量 --> <h2 :class="[className1, className2]">Hello Vue</h2>

甚至是对象和数组混合使用:

<!-- 数组中放一个对象语法 --> <h2 :class="[aaa, { active: isFlag }]">Hello Vue </h2>

而在React中就相对繁琐了, React在JSX给了我们开发者足够多的灵活性                  ,你可以像编写JavaScript代码一样                        ,通过一些逻辑来决定是否添加某些class:

例如用三元运算符判断是否添加类

<h2 className={`title ${isActive ? active : }`}>我是标题</h2>

或者将要添加的类放在一个数组中, 在让数组中的元素使用空格连接

<h2 className={[title, (isActive ? active : )].join()}>我是标题</h2>

当时如果是简单的类, 判断一个类是否添加还是比较容易, 如果需要判断多个, 处理起来就显得比较麻烦, 并且代码的可读性也会显得不友好

这个时候我们可以借助于一个第三方的库:classnames

很明显         ,这是一个用于动态添加classnames的一个库                。

首先需要安装classnames库: npm i classnames

classNames 是一个函数, 这个函数接受任意数量的参数              ,可以是字符串或对象

classNames(foo, bar); // => foo bar classNames(foo, { bar: true }); // => foo bar classNames({ foo-bar: true }); // => foo-bar classNames({ foo-bar: false }); // => classNames({ foo: true }, { bar: true }); // => foo bar classNames({ foo: true, bar: true }); // => foo bar classNames(foo, { bar: true, duck: false }, baz, { quux: true }); // => foo bar baz quux classNames(null, false, bar, undefined, 0, 1, { baz: null }, ); // => bar 1

示例代码

render() { const { isActive } = this.state return ( <div> {/* 传入两个字符串, 表示绑定两个class */} <h2 className={classNames("aaa", "bbb")}>标题</h2> {/* 明确绑定aaa类, 根据变量的布尔值决定是否绑定bbb */} <h2 className={classNames("aaa", {bbb: isActive})}>标题</h2> {/* js是无法识别短横线的, 如果是短横线连接的类名, 需要用引号包裹 */} <h2 className={classNames({ "aaa-bbb": isActive })}>标题</h2> {/* 有多个不确定是否添加的类名, 可以使用多个对象 */} <h2 className={classNames({aaa: isActive}, {bbb: isActive})}>标题</h2> {/* 也可以写在一个对象中 */} <h2 className={classNames({aaa: isActive, bbb: isActive})}>标题</h2> {/* 和vue一样, 也是支持数据的写法, 以及数组和对象的混合写法 */} <h2 className={classNames(["aaa", "ccc"])}>标题</h2> <h2 className={classNames(["aaa", {bbb: isActive}])}>标题</h2> </div> ) }

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
如何关闭开始菜单中的广告弹窗(如何关闭开始菜单中的广告) python __add__方法(如何使用python中的add函数?)