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

  • 稳岗返还资金最新账务处理
  • 驾驶员培训服务税率
  • 代扣代缴附加税减免
  • 成本 费用区别
  • 核定征收企业如何纳税
  • 分税制的内容有哪些?
  • 收到补助款的会计分录
  • 挂靠工程的所得税账务处理怎么做?
  • 事业单位发票名称是原来的怎么办
  • 员工销售家具取得的工资怎么写分录?
  • 固定资产预计净残值最后怎么处理
  • 分票报关合票出提单怎么清关
  • 企业注销难道必须要交房产税吗?
  • 企业租车费用怎么处理方法
  • 预收账款开票可以抵扣吗
  • 该期已经申报此税种且数据已提交,不能预约扣款
  • 预缴时少缴税款是否需要缴纳滞纳金?
  • 海关专用缴款书怎么认证?
  • 长期驻扎外地的员工
  • 专利权转销处理方案
  • 格式化时防止数据丢失
  • 税收是财政政策传导机制中重要的媒介之一
  • 自主研发全流程
  • php5.4+mysql
  • 电脑启动不了windows能进安全模式
  • 亡灵节mid
  • php获取网站内容
  • vue页面路由传参
  • 阿尔卑斯山百度百科
  • 跨年度发票会计分录
  • 提租补贴计入个税吗
  • 公司账户转法人账户
  • pytorch技巧
  • 手撕代码是啥意思
  • 新版个税申报系统查询
  • 什么叫日常业务
  • 服务行业人工费一般控制在多少合适
  • 什么叫总分类账簿
  • 盈余公积转增资本对会计要素的影响
  • 员工意外险税前扣除比例
  • 公司注销怎么做
  • 外币汇率分录
  • 银行日记账记错了怎么办
  • 预计负债的初始计量
  • 进口形式发票能证明商品是进口的吗
  • 物流运输业务
  • 投资性房地产处置的账务处理
  • 以下各项不属于肝郁气滞证表现的是
  • 简易计税项目可以抵扣进项税吗?
  • 小微企业和小规模纳税人的区别
  • 会计计算工资的步骤流程
  • 国家对民办幼儿园审批的条件有哪些?
  • centos编译器
  • Win10 Mobile 10563预览版微软官方模拟器下载
  • solaris配置ip地址
  • ubuntu下source、sh、bash、./执行脚本的区别详细介绍
  • 在mac设备上用到什么
  • sybase ase数据库用户名密码
  • 手把手教你安装使用国家反诈中心
  • onekey driver version是什么软件
  • 人脉系统
  • 无法登录所请求的数据库 用户sa登录失败
  • win7点关机关不了
  • unity怎么创建摄像机
  • javascript unicode与GBK2312(中文)编码转换方法
  • jquery中checkbox使用方法简单实例演示
  • jquery 案例
  • unity 3d教程
  • jquery的优点和缺点
  • python接口编写
  • 主机端口扫描程序设计python
  • 个人总结的几个方面
  • android刷题
  • 个体经营所得申报密码怎样设置
  • 金税三期怎么打完税凭证
  • 贵州铜仁苗族自治区
  • 百望税控盘怎么导出清单明细
  • 灵活就业登记审核查询
  • 南京江宁汽车过户手续及费用
  • 统一社会信用代码有什么用
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设