ホームページ > 記事 > ウェブフロントエンド > React は、選択された li をクリックしたときにそれを強調表示するメソッドを実装します。
この記事では、選択した li を強調表示するためのサンプル コードを主に紹介します。ページ上には、クリックした li を強調表示する必要があります。内容がとても良かったので、参考にさせていただきたいと思います。
単純な機能ですが、記録しておくと良いでしょう。ページ上には多くの li があり、クリックした li が強調表示されます。当時 jq を使用したときは、選択した要素を addClass に追加し、その兄弟要素を削除して、アクティブなスタイルを記述するだけでした。さて、react を使って同様の操作を実装する場合、私が考えるのは currentIndex を使用し、currentIndex がどの要素にあるかを判断して切り替えることです。
まず、レンダリングは次のとおりです:
コード:
class Category extends React.Component { constructor(props) { super(props) this.state = { currentIndex: 0 } this.setCurrentIndex = this.setCurrentIndex.bind(this) } setCurrentIndex(event) { this.setState({ currentIndex: parseInt(event.currentTarget.getAttribute('index'), 10) }) } render() { let categoryArr = ['产品调整', '接口流量', '负载均衡', '第三方软件调整', '安全加固', '性能控制', '日志查询', '业务分析']; let itemList = []; for(let i = 0; i < categoryArr.length; i++) { itemList.push(<li key={i} className={this.state.currentIndex === i ? 'active' : ''} index={i} onClick={this.setCurrentIndex} >{categoryArr[i]}</li>); } return <ul className="category">{itemList}</ul> } }
css部分
.category { padding-left: 0; &:after { content: ''; display: block; clear: both; } li { float: left; width: 23%; height: 40px; margin-right: 10px; margin-bottom: 10px; border: 1px solid $border-color; list-style: none; color: $font-color; line-height: 40px; text-align: center; font-size: 14px; cursor: pointer; &.active { border-color: #079ACD; } }
とてもシンプルですね。これらのLIを生成するときに要素にインデックスフラグを追加し、クリックされたときにevent.currentTarget.getAttribute('index')を使用してインデックスを取り出し、currentIndexの値を設定してからCSSを記述することです。スタイルが完成しました。
上記がこの記事の全内容です。その他の関連コンテンツについては、PHP 中国語 Web サイトをご覧ください。
関連する推奨事項:
React Native を使用した Flexbox レイアウトの紹介
React と Redux に基づいて SSR を実装する方法
以上がReact は、選択された li をクリックしたときにそれを強調表示するメソッドを実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。