位置: IT常识 - 正文

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

发布时间:2024-01-17
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岁零基础转行做网络工程师)

  • 新公司什么时候开始建账
  • 税收滞纳金是什么债权
  • 职工个人所得税
  • 股权转让产生的印花税
  • 季度盈利可以弥补以用以前年度亏损弥补
  • 地税补缴社保
  • 计划成本法领用原材料会计分录
  • 个体工商户怎么注销
  • 外经证预缴税款之后剩下的税款交到哪呢
  • 非汉语是什么意思
  • 推广费是广告费和业务宣传费吗
  • 新开公司季初季末人数和资产可以填0吗
  • 高新企业国家补助收入怎么入账
  • 税收滞纳金可以税前扣除吗
  • 电子商务平台怎么下载中标通知书
  • 财务报告成本
  • 工厂产品研发代码是多少
  • 如何分析财务报表看企业经营情况
  • 去年的成本发票怎么做账
  • 白醋洗脸有什么好处
  • 商标转让过程中公司转让
  • win11安卓子系统在哪打开
  • 跨年的发票冲红
  • php数组原理
  • 代扣代缴个税手续费返还政策
  • php常用的设计模式在开发中的实例
  • 电脑上fci是什么文件
  • 职工教育经费列支范围规定
  • 如何防范增值税的税收风险
  • 增值税发票开红字发票后账务处理?
  • 解决科学文化领域的矛盾应坚持的方针是
  • 工会筹备金计税依据
  • php照片上传
  • php _dir_
  • 怎么调试vue项目
  • mysqldump 导出数据
  • 销售货款无法收到怎么办
  • python初学笔记
  • 银行本票和汇票的定义
  • 自建厂房转固定资产如何办理手续
  • 产品维修费的会计怎么做
  • python爬虫详细教程
  • 公司收到保险公司退保费怎么账务处理
  • 债权债务转让会计分录
  • 生产企业免抵退红字冲减
  • 开票信息修改
  • ms sql 2012
  • mysql升级-5.1升级到5.7
  • 企业所得税是指哪些
  • 服务费开增值税专用发票
  • 以前年度损益调整结转到哪里
  • 工程材料费发票没拿到是否能预提费用?
  • 来料加工的账务处理新收入准则
  • 分期付款购入固定资产该如何做账务处理呢?
  • 免征的增值税如何处理
  • 企业资产负债表怎么做
  • 取得房租发票的租赁费可以抵税吗
  • 标准成本法计算公式图
  • 成本与费用的区别联系
  • win8怎么设置
  • Win10预览版桌面图标和任务栏不翼而飞怎么办?
  • centos安装问题
  • 安装操作系统win10
  • centos 安装源设置出错
  • macbookpro如何点击
  • python sed
  • txt文件打开
  • win8关机慢怎么办
  • Unity3D游戏开发引擎
  • javascript自定义属性
  • node.js项目结构
  • dos用处
  • perl命令
  • 常见的dos命令及功能
  • python获取当前路径的方法
  • 创建网元
  • node js作用
  • js鼠标点击事件监听
  • 福建地税网上办事大厅
  • 地税局基层职位怎么样
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号