我是一个新的反应,所以我很抱歉,如果这是一个愚蠢的问题,
当按下按钮时,我正试图将css样式的类名切换为div,按钮是页面中的一个单独组件,我不知道如何连接两个原来使用jquery我有这样的东西:
componentWillMount() {
$(document).ready(function() {
var header = $('header'),
btn = $('button.toggle-nav');
btn.on('click', function() {
header.toggleClass('active');
});
});
}
但我意识到它没有在第一次加载页面时运行。非常感谢所有的帮助!
我已经取出了按钮组件,我现在有类似的东西,
<header className="contain active">
<Navigation/>
<button className="toggle-nav">
<span className="fa fa-bookmark-o" aria-hidden="true"></span>
</button>
<div className="divider"></div>
澄清我试图让按钮切换标题的“活动”类名
您希望了解标头是否处于活动状态。它看起来像这样。
class Test extends React.Component {
constructor(...args) {
super(...args)
this.state = { active: false }
this.onButtonClick = this.onButtonClick.bind(this)
}
onButtonClick() {
this.setState((state) => ({ active: !state.active }))
}
render() {
return (
<>
<header className={`contain ${this.state.active ? 'active' : ''}`>
<Navigation/>
<button className="toggle-nav" onClick={this.onButtonClick}>
<span className="fa fa-bookmark-o" aria-hidden="true"></span>
</button>
<div className="divider"></div>
</>
)
}
}
该按钮通过onClick回调,切换活动状态。作为状态更改的结果,组件将重新呈现,并且将根据状态值有条件地呈现活动类名称。