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

  • 如何修改纳税申报密码
  • 收到的实收资本都能用来做什么
  • 汽车销售分期付款的账务处理
  • 个人去税务局开专票需要提供什么
  • 文化建设税是含税价吗
  • 汇兑损益属于企业成本吗
  • 固定资产加速折旧法
  • 业务招待费怎么做会计分录
  • 长期负债率分析
  • 公司一上来要签三年
  • 报损失怎么报
  • 专项维修资金的,由县级
  • 现房销售土增税怎么缴纳
  • 国有资产无偿划转管理办法
  • 购买税控设备,享受何种优惠政策
  • 漏提折旧可以所得税扣除吗
  • 增值税没有按时缴纳会影响开票吗
  • 允许列支的捐赠比例
  • 新金融工具准则投资收益
  • 长期待摊会计处理
  • 食堂费用没有发票能挂账吗
  • 企业的养老金根据什么扣除
  • 对外开具发票
  • 注销税务登记后多久注销工商登记
  • 旧机器设备出口
  • 正回购和逆回购的区别
  • 将自产产品无偿赠送税务处理
  • 财务费用余额在借方是正数还是负数
  • 如何玩转win11
  • 非正常损失为什么不赔偿
  • 小规模纳税人如何申报增值税
  • u盘做的启动盘在哪里
  • 税务实名认证是不是就是税务登记
  • 支付宝花呗服务升级有什么用
  • url是什么软件
  • 加勒比海百科
  • 圣胡安岛战争
  • php操作文件的常用函数
  • 一般纳税人简易征收3%可以开专票吗
  • php面向对象优点,缺点
  • 共管账户可以转账吗
  • unity怎么打包unitypackage
  • discuz php版本
  • 定额发票在哪查真伪
  • 承包安装工程活怎么接
  • phpcms v9安装教程
  • 首涂第二十一套模板
  • python 动态
  • 三代手续费操作流程
  • 库存现金写三栏式明细账还是写现金日记账还是两个都写
  • 公司汽车转卖给个人税率
  • ubuntu20.04vim
  • 毛利润和纯利润
  • 收到承兑的账务处理
  • 合并企业如何缴纳印花税
  • 房屋租赁合同印花税怎么计算
  • 现金流量表每月要报吗
  • 房地产企业城建税和教育费附加怎么算
  • 可供出售金融资产包括哪些内容
  • 资本公积转增股本所有者权益会变吗
  • 全额工资和实发工资
  • 物流公司的会计怎么样
  • 加盟费交税
  • 注册资本和实收股本的区别
  • 固定资产清理期末
  • mysql千万级分页优化
  • centos配置http
  • centos安装软件教程
  • 在Linux系统中安装镜像步骤
  • /etc/init.d/rcs
  • shell 多个文件合并
  • jqueryui easyui
  • nodejs连接mongodb副本集
  • js应用实例
  • jquery制作简单的网页
  • 江苏省国税总局
  • 发票打印怎么调整尺寸
  • 怎么查询高速路封闭和开通
  • 财政资金存在问题
  • 建筑业统一发票税率
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设