0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

特定のページからのアクセスではアコーディオンを開いて表示させる

Posted at

問題

アコーディオンで作られた FAQ のページがあります。よく見かけますね。
1616853856872.png

通常こちらのページにアクセスした時は初期値では全てアコーディオンが閉じている仕様です。

ですが、あるページからアクセスした時は、アコーディオンの一つを開いた状態で遷移したい時があります。

例えば、あるページに「問い合わせはこちら」のリンクがあり、問い合わせ先は FAQ の Question に記載されている時などです。

1616854102838.png

解決法

遷移元の HREF の値に特定の文字列を入れる(アンカーリンク)
遷移先で自身の URI の文字列を取得。
特定の文字列(アンカーリンク)を検出できたらアコーディオンを開く処理をする

ソースコード

リンク元のページ

HREF の値に #acc03 を記述します。

index.html
<a href="target.html#acc03">リンク先</a>

リンク先のページ(FAQ)

アコーディオンを開閉させるコードはこちらの記事では省略しますが、is-open というクラスをトグルさせて表示非表示を切り替えているものとします。

faq.html
<div class="accordion">
  <div id="acc01" class="accordion-item">
    <h2 class="accordion-title">Question 1</h2>
    <div class="accordion-content">
      <p>This is an Answer 1</p>
    </div>
  </div>
  <div id="acc02" class="accordion-item">
    <h2 class="accordion-title">Question 2</h2>
    <div class="accordion-content">
      <p>This is an Answer 2</p>
    </div>
  </div>
  <div id="acc03" class="accordion-item">
    <h2 class="accordion-title">Q. 問い合わせ先はどちらでしょうか。</h2>
    <div class="accordion-content">
      <p>A. 問い合わせ先はこちらです。</p>
    </div>
  </div>
</div>

JS

リンク先のページ(FAQ)のアドレスバーの文字列を取得して、
もし、その文字列に #acc03が含まれていたら、
id="acc03" の要素に is-open クラスを付与します。
※こちらのJavaScript は FAQ ページで読み込むものです。

var url = location.href;
if (url.match(/#acc03/)) {
  var acc = document.getElementById('acc03');
  acc.classList.add('is-open');
}
0
0
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?