您现在的位置是:网站首页> 编程资料编程资料
React通过classnames库添加类的方法_React_
2023-05-24
421人已围观
简介 React通过classnames库添加类的方法_React_
React添加Class的方式
在vue中添加class是一件非常简单的事情:
你可以通过传入一个对象, 通过布尔值决定是否添加类:
你也可以传入一个数组:
Hello Vue
Hello Vue
甚至是对象和数组混合使用:
Hello Vue
而在React中就相对繁琐了, React在JSX给了我们开发者足够多的灵活性,你可以像编写JavaScript代码一样,通过一些逻辑来决定是否添加某些class:
例如用三元运算符判断是否添加类
我是标题
或者将要添加的类放在一个数组中, 在让数组中的元素使用空格连接
我是标题
当时如果是简单的类, 判断一个类是否添加还是比较容易, 如果需要判断多个, 处理起来就显得比较麻烦, 并且代码的可读性也会显得不友好
这个时候我们可以借助于一个第三方的库: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 ( {/* 传入两个字符串, 表示绑定两个class */} 标题
{/* 明确绑定aaa类, 根据变量的布尔值决定是否绑定bbb */} 标题
{/* js是无法识别短横线的, 如果是短横线连接的类名, 需要用引号包裹 */} 标题
{/* 有多个不确定是否添加的类名, 可以使用多个对象 */} 标题
{/* 也可以写在一个对象中 */} 标题
{/* 和vue一样, 也是支持数据的写法, 以及数组和对象的混合写法 */} 标题
标题
) } react之中利用第三方库添加类名classnames
react之中添加动态类名没有在vue之中那么方便,可以使用第三方库进行
1、安装库
yarn add classnames
2、使用
原生在react之中添加class方法:
1
//下面这个字符串拼接添加类名记得" active"前需要一个空格2
//下面就避免上述的还需要加空格3
使用第三方库
import classNames from "classnames"
//一次多个类名1
//根据变量的真否判断是否添加类名2
//数组的形式实现3
到此这篇关于React通过classnames库添加类的文章就介绍到这了,更多相关React classnames库添加类内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- React路由渲染方式与withRouter高阶组件及自定义导航组件应用详细介绍_React_
- 使用nodejs解析json数据_node.js_
- React状态管理Redux的使用介绍详解_React_
- 停止编写 API函数原因示例分析_JavaScript_
- 一次vue项目优化的实际操作记录_vue.js_
- Nodejs如何使用http标准库异步加载https请求json数据_node.js_
- Typescrip异步函数Promise使用方式_javascript技巧_
- Typescript使用修饰器混合方法到类的实例_javascript技巧_
- vue3 hook自动导入原理解析_vue.js_
- 关于TypeScript声明合并_javascript技巧_
