我的编程空间,编程开发者的网络收藏夹
学习永远不晚

React中如何设置多个className

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

React中如何设置多个className

React设置多个className

在一个元素上设置样式,有一个固定的样式,然后还有一个使用三元运算符根据条件添加的样式。

比如说有一个固定样式"title":

<div className="title">标题</div>

然后还要一个点击高亮的样式:

<div className={index === this.state.active ? "active" : null}>标题</div>

不能这样写:

<div className="title" className={index === this.state.active ? "active" : null}>标题</div>

方法一:ES6 模板字符串 ``

className={`title ${index === this.state.active ? 'active' : ''}`}

方法二:join("")

className={["title", index === this.state.active?"active":null].join(' ')}

方法三:classnames(需要下载classnames)

const classNames = require('classnames');
 
const Button = React.createClass({
  // ...
  render () {
    const btnClass = classNames({
      btn: true,
      'btn-pressed': this.state.isPressed,
      'btn-over': !this.state.isPressed && this.state.isHovered
    });
    return <button className={btnClass}>{this.props.label}</button>;
  }
});

个人喜好 第二种,一方面代码量少,另一方面方便对 className数组的增加与删除。

React className的写法

本文中展示的,都是多className情况下的写法,提供的写法都是笔者个人的一些经验总结,并不一定是最标准的写法,但是符合高内聚,低耦合的工程思想。

(ps:csdn里貌似 jsx 的代码高亮有些问题,我就用模板字符串包住了)

模板字符串的写法

//写法一
export default class A extends Component {
    state ={
        work: true,
        sabbatical: false,
    }
    render(){
        return (
            `<div 
                className={`calend-item ${work ? '' : "off-day"} ${sabbatical ? "sabbatical" : ''}`}
            >
                {}
            </div >`
        )
    }
}
 
//写法二
export default class B extends Component {
    state ={
        work: true,
        sabbatical: false,
    }
    render(){
        return (
            `<div
                className={`
                    'calend-item'
                    ${work ? ''  : "off-day"}
                    ${sabbatical ? "sabbatical" : ''}
                `}
            >
                {}
            </div >`
        )
    }
}
 

写法一:模板字符串非折叠的写法,不仅代码看起来非常的恶心,而且万一少一个空格隔开,是没有错误提示的(这点是最致命的),同时最后render出的html结构中还会带来无意义的空格(见下图 )。

写法二:模板字符串折叠的写法,虽然代码看起来清楚了些也不会少敲空格,但是最后render出的html结构中不仅有空格,还有换行(见下图)显然是顾此失彼。

formatClass的方法

显然模板字符串带来了很多的麻烦。

既然className本质上就是要得到一个字符串,那么我们就自己写个方法来得到目标字符串。

//写法三
export default class A extends Component {
    state ={
        work: true,
        sabbatical: false,
    }
    render(){
        //可以将所有的className属性都塞入下面的对象中
        let _class = formatReactClass({
          item: [
            'calend-item',
            work ? null : "off-day",
            sabbatical ? "sabbatical" : null,
          ]
        })
 
        return (
            `<div className={_class.item} >
                {}
            </div >`
        )
    }
}
 
//下面俩函数可以放到自己项目里的工具函数模块中
 

function formatReactClass(classObj) {
  return mapObj(classObj, i =>
    Array.isArray(i) ? i.filter(i => i && i !== '').join(' ') : i
  );
}
 

function mapObj(Obj, callback) {
  let res = {};
  Object.keys(Obj).forEach(i => (res[i] = callback(Obj[i])));
  return res;
}

写法三:我们将所有的className属性的值都塞入一个对象中(高内聚思想的体现),同时使用formatReactClass工具函数格式化我们的_class对象。使我们的无论是代码中,还是最后render出的html结构中的class属性都十分的规整。

小结:除了上述写法、还可以引入如 classnames 等三方的库来解决问题。笔者的写法不一定是最好的,但无论是从开发代码的规整度,还是从二次翻阅代码的舒适度、都是目前个人觉得不错的一个写法。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

React中如何设置多个className

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

React中如何设置多个className

这篇文章主要介绍了React中如何设置多个className问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-17

react中如何设置focus

这篇文章主要介绍了react中如何设置focus的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇react中如何设置focus文章都会有所收获,下面我们一起来看看吧。react中设置focus的方法:1、在com
2023-07-04

如何给vps设置多个账号

要给VPS设置多个账号,您可以按照以下步骤进行操作:1. SSH登录到您的VPS服务器。2. 创建新的用户账号。可以使用以下命令创建新的用户账号(替换"newuser"为您想要的用户名):```sudo adduser newuser```
2023-08-11

react如何设置div高度

这篇文章主要介绍“react如何设置div高度”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“react如何设置div高度”文章能帮助大家解决问题。react设置div高度的方法:1、通过css方式实
2023-07-04

react如何设置style属性

这篇文章主要讲解了“react如何设置style属性”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react如何设置style属性”吧!react设置style属性的方法:1、通过“
2023-07-05

SpringMVC拦截器如何设置多个path

这篇文章主要介绍SpringMVC拦截器如何设置多个path,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!SpringMVC拦截器path路径的坑SpringMVC提供了很方便的拦截器供我们开发使用。在配置文件中通过
2023-06-25

react native删除线如何设置

今天小编给大家分享一下react native删除线如何设置的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。react nat
2023-07-04

react页面中存在多个input时巧妙设置value属性方式

这篇文章主要介绍了react页面中存在多个input时巧妙设置value属性方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-05-20

如何使用UniApp Pages设置多个标题?

标题:UniApp Pages 可以设置第二个标题UniApp 是一款基于 Vue.js 开发的跨平台开发框架,可以使用同一份代码构建 iOS、Android、H5 和微信小程序等多个平台的应用程序。在 UniApp 中,页面是开发中的重要部分,而页面中的标题也是不可或缺的元素。与此同时,在某些情况下,一个页面需要设置多个标题,这时UniApp Pages就派上用场。什么是Un
2023-05-14

mfc如何设置多个edit不可输入

要设置多个Edit控件为不可输入,可以使用以下方法:使用SetReadOnly函数设置Edit控件为只读模式。例如,假设有一个名为m_edit1的Edit控件,可以使用以下代码将其设置为只读模式:m_edit1.SetReadOnly(TR
2023-10-21

php post请求如何设置多个参数

本篇内容介绍了“php post请求如何设置多个参数”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先,我们需要了解一些基本的HTTP请求知
2023-07-05

jquery如何设置元素多个属性值

今天小编给大家分享一下jquery如何设置元素多个属性值的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。jquery设置元素多
2023-07-05

怎么在golang中设置多个GOPATH

怎么在golang中设置多个GOPATH?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。什么是golanggolang 是Google开发的一种静态强类型、编译型
2023-06-14

mysql中如何设置两个主键

在 mysql 中设置两个主键的方法有两种:复合主键:alter table table_name add primary key (column1, column2);多列主键:alter table table_name add pri
mysql中如何设置两个主键
2024-04-29

react native如何设置页面背景色

这篇文章主要讲解了“react native如何设置页面背景色”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react native如何设置页面背景色”吧!react native设置页面背
2023-07-04

react如何实现多个页面之间跳转

本文小编为大家详细介绍“react如何实现多个页面之间跳转”,内容详细,步骤清晰,细节处理妥当,希望这篇“react如何实现多个页面之间跳转”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。react多个页面之间跳转
2023-07-04

vue如何实现同时设置多个倒计时

这篇文章主要介绍vue如何实现同时设置多个倒计时,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下html如下:
2023-06-15

编程热搜

目录