位置: IT常识 - 正文

React通过classnames库添加类(react中key)

编辑:rootadmin
React通过classnames库添加类 React添加Class的方式

推荐整理分享React通过classnames库添加类(react中key),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:react中key,react中classname,react中classname,react的class,react中classname,react通过iframe引用本地html,react通过标签获取元素,react通过ref属性获取属性,内容如对您有帮助,希望把文章链接给更多的朋友!

在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通过classnames库添加类(react中key)

而在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 barclassNames('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> )}
本文链接地址:https://www.jiuchutong.com/zhishi/300159.html 转载请保留说明!

上一篇:Vue 之 vue3 与 TS 的配合使用整理(vue3和ts)

下一篇:26岁转行网络安全,成功上岸安全开发!(27岁零基础转行做网络工程师)

  • 民办非企业收到捐赠固定资产
  • 预缴税款计算公式
  • 什么叫差额征税呢
  • 主营业务收入属于什么类
  • 企业文化事业建设费计算
  • 企业会计核算基础
  • 小规模纳税人销售农产品税率是多少
  • 存在问题的具体表现和产生问题的原因分析
  • 研发项目领原料加工成产品会计处理是怎样的?
  • 员工无息借款个人所得税
  • 没有发票怎么报销入账
  • 水利基金计提比例
  • 个税合理避税的意义
  • 专票遗失需要怎么处理?
  • 财政收据可以抵税吗
  • 企业外购零部件可以入哪个会计科目核算?
  • 不用开票的收入有哪些
  • 一次性领取的年金 税率表
  • 如何使用ping命令诊断网络故障
  • 汇算清缴补交的所得税会计分录
  • win10如何获得管理员权限修改文件
  • 长期待摊费用账务处理包括哪两部分
  • ramaint.exe - ramaint是什么进程 有什么用
  • adv举例
  • deepin怎么删除账户
  • php字符串型数据的定义方式
  • 销售已使用过的固定资产增值税税率
  • 承租人经营租赁会计分录
  • 股票公允价值减值怎么做账
  • 预收外汇会计分录
  • php模式
  • 领用包装物会计科目
  • 进项税额转出余额在贷方怎么处理
  • 税控盘的发票怎么做账
  • 利息增值税及附加计算
  • 采购员出差预借差旅费
  • yolo v4 v5
  • mysql查找重复项
  • phpcms怎么样
  • 小规模所得税申报表利润总额是填季报吗
  • 免征和抵扣税额的区别
  • 其他综合收益在利润表的哪个位置哪里
  • ajax写接口
  • 怎么摊销租金
  • 中药饮片增值税率是多少
  • 购买增值税发票属于什么科目?
  • Mysql中 show table status 获取表信息的方法
  • 社保缴费基数应该怎么算
  • 房租可以一次性抵扣吗
  • 交车辆保险的车是什么车
  • 新入股公司股权转让
  • 出口应纳增值税
  • 政府补贴收入的账务处理
  • 如果我们交了房租,对方不给我们开发票
  • 销售发奖金感谢说说
  • 短期理财收益账务分录
  • 什么是记账凭证?有哪些分类
  • 学会整理内容
  • scanfile.exe
  • u 盘装wⅰn10系统
  • windows7文件夹选项在哪里
  • image driver
  • windows找不到硬盘驱动器
  • 武汉做无创要预约吗
  • win10系统以太网连接图标不见了怎么办
  • win7右下角的网络连接不显示
  • win8自带软件哪些可以卸载
  • 在linux中使用apache发布web服务时默认web站点
  • js创建对象的三种方式区别
  • appiumforwindows的简单安装和启动(安卓)
  • node做爬虫
  • python自动生成
  • 延时加载js文件
  • android studio的app
  • js读取文件大小
  • css中position的用法
  • 地下车库是否缴房产税
  • 生活垃圾处理合作协议
  • 劳办发1994第48号文全文原文
  • 加计扣除的税收分类编码
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设