首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >同构式加载器-如何添加“活动”类

同构式加载器-如何添加“活动”类
EN

Stack Overflow用户
提问于 2018-05-01 20:16:32
回答 3查看 384关注 0票数 1

我正在使用反应启动器-工具包并构建一个如下所示的列表组件:

代码语言:javascript
复制
import React from 'react';
import withStyles from 'isomorphic-style-loader/lib/withStyles';
import s from './CommandList.css';

const CommandList = () => {
  return (
    <ul className={s.commandList}>
      {data.commands.map((command, index) => (
        <li 
          key={index}
          className={s.commandListItem}>
          {command.command}
        </li>
      ))} 
    </ul>
  );
};

export default withStyles(s)(CommandList);

我试图在我的li项中添加一个“活动”类,但不确定如何添加该类?我尝试使用classnames库,但不确定如何从样式中获得第二个类。当我传入字符串"active“时,样式不会被导入。

代码语言:javascript
复制
import cx from 'classnames';

<li className={cx(s.commandListItem, {'active': command.active })}>

我的问题是我会怎么做

代码语言:javascript
复制
<li className={cx(s.commandListItem, {s.active: command.active })}>
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-05-01 20:42:18

<li className={cx(s.commandListItem, {[s.active]: command.active })}>

参见[]对象键表示法

票数 0
EN

Stack Overflow用户

发布于 2018-05-01 20:39:10

弄明白了。我用错了classnames。我需要导入classnames/bind

代码语言:javascript
复制
import s from './CommandList.css';
import classnames from 'classnames/bind';

let cx = classnames.bind(s);

然后,我可以像我想要的那样传入'active‘字符串:

代码语言:javascript
复制
<li className={cx(s.commandListItem, {'active': command.active })}>

现在,cx var名称更有意义了。

票数 1
EN

Stack Overflow用户

发布于 2018-09-17 14:46:27

React中的className是String,您必须将所有对象转换为String。

首先,创建要分配给类的类数组。

然后将类名数组转换为字符串。

代码语言:javascript
复制
className={[s.commandListItem, 'active'].join('')}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50123213

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档