すべてのアコーディオンのオンとオフを切り替えるボタンを設定するにはどうすればよいですか?
<p>次のコードを使用して、折りたたみ可能なアコーディオンを作成するコンポーネントがあります。</p>
<pre class="brush:php;toolbar:false;">import React、{useState} from 'react';
const Collapsible = (props) =>{
const [open, setOpen] = useState(false);
const toggle = () => {
setOpen(!open);
}
戻る(
<div>
<button className={props.level} onClick={toggle}>{props.label}</button>
{開く && (
<div className="切り替え">
{props.children}
</div>
)}
</div>
)
}
デフォルトをエクスポート Collapsible;</pre>
<p>メイン アプリケーションのいくつかの場所で使用し、場合によっては他のアコーディオンでも使用します。アコーディオンはデータに基づいて動的にレンダリングされるため、ページ上にアコーディオンがいくつあるのか実際にはわかりませんでした。これを念頭に置いて、固定数を設定する必要がなく、メイン アプリケーションのすべてのアコーディオン (つまり、他のコンポーネントの一部のアコーディオン) をレンダリングする必要もなく、すべてのアコーディオンをオン (およびオフ) にするボタンをメイン アプリケーションに作成したいと考えています。そしてメイン アプリケーションにインポートされます)。 </p>
<p>これを実現するために ref フックを使用してみました。</p>
<ol>
<li>折りたたみ可能なコンポーネントのボタンに ref を追加し、props を介して親コンポーネントからアクセスします。
</ol>
<pre class="brush:php;toolbar:false;"><button className={props.level} onClick={toggle} ref={props.innerRef}>{props.label}</button> ;</pre>
<ol start="2">
<li>メイン アプリケーションに次の参照を追加します。</li>
</ol>
<pre class="brush:php;toolbar:false;">const childRef = useRef();
const openClick = () => {
childRef.state = true;
}
const closeClick = () => {
childRef.state = false;
}</pre>
<ol start="3">
<li>メイン アプリケーションで次のボタンを使用します。</li>
</ol>
<pre class="brush:php;toolbar:false;"><ボタン onClick = {openClick}>
すべて展開
</ボタン>
<ボタンオンクリック = {closeClick}>
すべて折りたたむ
</ボタン></前>
<ol start="4">
<li>レンダリング時にアコーディオンに参照を追加します: </li>
</ol>
<pre class="brush:php;toolbar:false;"><Collapsible label="" level="content" innerRef={childRef}></pre>
<p>これは実際には何も起こりません。おそらく、ステップ 2 で状態にアクセスしようとした方法が間違っていたためです。しかし、試してみる価値はあると思いました...</p>
<p>これが可能かどうかについて何かアイデアはありますか? </p>