javascript - 如何通过动态 react 更改类的 css

标签 javascript html css reactjs state

我的问题是关于通过另一个类更改类的 CSS。我知道,如果我们尝试更改的元素与所选元素相邻或同级,我只能更改 CSS。

我的目标是在选择“血腥玛丽”链接时更改页眉和选项卡类的背景颜色,但我不知道如何完成此操作。 我正在使用 React,而我的想法是使用状态。默认为白色,当血腥玛丽链接处于事件状态时,它会将状态从白色更改为黑色。我还计划更改字体颜色等其他样式,但主要思想保持不变,通过 React 动态更改样式。

我已将我的代码精简到最基本的部分,因此它看起来更干净。如果您能提供一些帮助,我们将不胜感激。

  class Header extends React.Component {
    render () {
        return(
          <div>
            <div className='header'>         
              <li className='tabs'><NavLink className='style' 
              activeClassName='selected'>Home</NavLink></li>

              <li className='tabs'><NavLink className='style' 
              activeClassName='selected'>Team</NavLink></li>

              <div className='dropdown'>
                <div className='tabs'><NavLink className='style projectstab' 
                activeClassName='selected'>Projects</NavLink></div>
                <div className='dropdown-content'>
                  <a>
                    <p className='dropdown-li'>
                    </p>
                    <NavLink activeClassName='bloodyselected'>
                      Bloody Mary
                    </NavLink>
                  </a>
                </div>
              </div>

              <li className='tabs'><NavLink className='style' 
              activeClassName='selected'>Contact Us</NavLink></li>
            </div>
      )
    }
  }

最佳答案

classNamestyle 指令接受动态值的插值。您可以使用它来实现您想要的。

class Hello extends React.Component {
  constructor(props) {
    super(props);
    this.state = { style: {} };
    this.bloodyMary = this.bloodyMary.bind(this);
  }

  bloodyMary() {
    this.setState({
      style: { backgroundColor: 'red' },
      class: 'someclass'
    });
  }

  render() {
    return <div style={this.state.style} className={this.state.class}>
      <a onClick={this.bloodyMary}>Bloody Mary</a>
    </div>;
  }
}

看看 online demo

关于javascript - 如何通过动态 react 更改类的 css,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46900320/

相关文章:

html - 由于内容过多,页脚错位

javascript - 路由器解析不会注入(inject) Controller

javascript - 根据主输入类型="file"(多个)元素创建多个输入类型="file"元素及其对应的值(FileList)

javascript - 如果它们都在服务器上运行,如何检查选择了哪个单选按钮?

javascript - 向辅助技术发出关于 div 可见性变化的警报,但不向辅助技术发出关于后续更新的警报

javascript - 单击图像后如何显示弹出窗口

html - 媒体查询转换问题

javascript - 使用 Zurb Foundation 在顶部栏中使用 Postfix 按钮输入

javascript - MySQL 存储过程使用express.js 返回未定义

javascript - 当屏幕最大化时,div 模式弹出窗口在 IE 上无法正确呈现,在 Chrome 上工作正常