位置: 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岁零基础转行做网络工程师)

  • realme gt neo2怎么关闭广告(realmegtneo2怎么刷机)

    realme gt neo2怎么关闭广告(realmegtneo2怎么刷机)

  • oppo手机怎么取消黑屏手势(oppo手机怎么取卡)

    oppo手机怎么取消黑屏手势(oppo手机怎么取卡)

  • 为什么注册不了12306(为什么注册不了个人所得税app)

    为什么注册不了12306(为什么注册不了个人所得税app)

  • 抖音企业号昵称必须要用企业名吗(抖音企业号昵称修改审核要多久)

    抖音企业号昵称必须要用企业名吗(抖音企业号昵称修改审核要多久)

  • 小米手机图片重命名怎么弄(小米手机图片重复)

    小米手机图片重命名怎么弄(小米手机图片重复)

  • oppo手机怎么没有nfc功能(oppo手机怎么没有声音了)

    oppo手机怎么没有nfc功能(oppo手机怎么没有声音了)

  • iqooz1处理器相当于骁龙多少(iqoo z1处理器什么级别)

    iqooz1处理器相当于骁龙多少(iqoo z1处理器什么级别)

  • 荣耀x10什么时候发布(荣耀x10什么时候升级鸿蒙3.0)

    荣耀x10什么时候发布(荣耀x10什么时候升级鸿蒙3.0)

  • 微信可以加多少好友就会满(微信可以加多少人才满)

    微信可以加多少好友就会满(微信可以加多少人才满)

  • 电脑开机出现americanmegatrends怎么办(电脑开机出现american megatrends)

    电脑开机出现americanmegatrends怎么办(电脑开机出现american megatrends)

  • oppo手机小布怎么语音唤醒(oppo手机小布怎么直接唤醒)

    oppo手机小布怎么语音唤醒(oppo手机小布怎么直接唤醒)

  • aicde主要包含什么(aicd的意义)

    aicde主要包含什么(aicd的意义)

  • pic什么意思(pic什么意思医学)

    pic什么意思(pic什么意思医学)

  • 蓝牙耳机连上还是外放(蓝牙耳机连上还是外放声音)

    蓝牙耳机连上还是外放(蓝牙耳机连上还是外放声音)

  • 多媒体处理的是(多媒体处理软件包括)

    多媒体处理的是(多媒体处理软件包括)

  • word怎么打上标(word怎么打上标符号)

    word怎么打上标(word怎么打上标符号)

  • 手机怎么恢复qq聊天记录(手机怎么恢复qq删除的说说)

    手机怎么恢复qq聊天记录(手机怎么恢复qq删除的说说)

  • ios13亮度自动调节怎么关(ios13.5自动亮度)

    ios13亮度自动调节怎么关(ios13.5自动亮度)

  • 觅马出行退款账户是啥(觅马出行退款账户从哪里找)

    觅马出行退款账户是啥(觅马出行退款账户从哪里找)

  • 三星bixby怎么设置说话(三星bixby页面的设置不见了)

    三星bixby怎么设置说话(三星bixby页面的设置不见了)

  • 目前管控平台适应哪几种认证方式(目前管控平台适应哪种认证方式)

    目前管控平台适应哪几种认证方式(目前管控平台适应哪种认证方式)

  • word文档虚线怎么画(word文档 虚线)

    word文档虚线怎么画(word文档 虚线)

  • 计算机网络分为(计算机网络分为哪三种)

    计算机网络分为(计算机网络分为哪三种)

  • 华为p30锁屏时间位置(华为P30锁屏时间怎么调到下方)

    华为p30锁屏时间位置(华为P30锁屏时间怎么调到下方)

  • 四芯网线接法是什么?(4芯网线插线顺序图)

    四芯网线接法是什么?(4芯网线插线顺序图)

  • 【论文阅读】2022年最新迁移学习综述笔注(Transferability in Deep Learning: A Survey)(论文阅读网站排行榜)

    【论文阅读】2022年最新迁移学习综述笔注(Transferability in Deep Learning: A Survey)(论文阅读网站排行榜)

  • 纳税义务发生时间 纳税期限
  • 银行的划分标准
  • 电汇汇票和电汇的异同点
  • 进料加工出口退税政策
  • 地方教育费附加的计税依据是什么
  • 新公司筹建期要做账吗
  • 普通发票作废影响额度吗
  • 坏账核销计入营业利润吗
  • 发票二维码只有一半可以收吗
  • 收到的房租增值税专用发票可以抵扣吗
  • 小微企业所得税优惠政策最新2022
  • 机动车销售统一专票可以抵扣进项税额吗
  • 应付账款的进项税分录
  • 所得税汇算清缴账务处理
  • 其他贷款服务的内容包括
  • 辅助生产交互分配后的实际费用应在进行分配
  • 上市公司个税手续流程
  • 企业以前年度的关联交易与预约定价安排
  • 出口公司要交哪些税费
  • 通讯费能开专票吗
  • 某物业公司组织工人进入下水道
  • 建筑劳务公司人员结构
  • 计提汇算清缴涉及到不是当年费用怎么记账
  • 防暑降温列支什么费用
  • 备查账簿根据企业的实际需要设置没有固定的格式要求
  • 跨地区经营汇总纳税企业所得税
  • 失控发票进项转出申报
  • 公司代缴的个税怎么查询
  • 逾期交房违约金怎么算
  • 升级鸿蒙系统后
  • 去年的费用今年报销如何记账
  • 为什么电脑连上蓝牙耳机却是外放
  • thinkphp怎么用
  • PHP:Memcached::getServerByKey()的用法_Memcached类
  • pc程序是什么
  • 月度计提所得税怎么调整
  • 结转已销产品实收成本
  • 个人通讯费可以税前扣除吗
  • 信用减值损失属于损益类科目吗
  • php中实现文件上传需要用到哪几个函数
  • php curlfile
  • laravel分页
  • 新成立的公司怎么算生育津贴
  • 长期待摊费用是什么科目
  • 织梦使用教程
  • 已经抵扣的发票红字信息表怎么开
  • 增值税调整怎么结算
  • 安装SQL2005的实训体会
  • 金税盘锁死日期哪里看
  • 应付劳务费怎么做账
  • 跨年收入退款如何处理
  • 第一次建账要填期初余额吗
  • 以前年度是指哪一年
  • 预借备用金的会计分录
  • 担保贷款借款人死亡
  • 发票认证完了该怎么取消
  • 劳务公司拿什么挣钱
  • 分享一下相亲时碰见过哪些奇葩事
  • mac mysql初始密码
  • sqlserver的case 用法
  • linux解释
  • mmc不能打开文件services.msc
  • mac死机按什么都没用
  • win8系统如何安装惠普打印机
  • 苹果mac系统怎么截屏快捷键
  • qtask.exe - qtask是什么进程 有什么用
  • win7的系统升级win10
  • win8系统怎么设置共享局域网
  • w10系统每次启动都要选择系统
  • 使用jquery实现的项目
  • jquery技巧
  • python模糊搜索字符串
  • 基于像素的分类方法
  • bootstrap基础教程
  • 根据安全生产法的规定,生产经营单位
  • jquery使用css
  • 安卓怎么记录时间
  • 申请电子发票需要去税务局吗
  • 安徽税务网上申报领取发票
  • 辽宁朝阳丧葬费标准2022
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设