CSSトランジションは高さを変更することで要素を拡大したり縮小したりします。

CSSトランジションは高さを変更することで要素を拡大したり縮小したりします。

一般的な開発ニーズとして、要素の一部を必要になるまで折りたたんでおきたいことが挙げられます。 Bootstrap や JQuery などの一般的なフレームワークには、トランジション効果を提供するものがあります。ただし、CSS Transition を使用すると、高さの遷移に関して非常に柔軟に対応できます。したがって、プロジェクトに追加のフレームワークを含める必要はありません。
次に、CSS Transition を使用して height プロパティをアニメーション化する方法と、問題点と解決策について見ていきましょう。
効果は👉で確認できます

遷移の高さ

私たちが実現したいのは、「もっと見る」ボタンをクリックすると、要素の高さが増加して記事のすべてのコンテンツが表示され、もう一度クリックすると元のサイズに戻ることです。
このための CSS クラスを作成します。このクラスは、「詳細を表示」ボタンがクリックされたときに JavaScript を使用して <article> 要素に追加されます。
まず、HTML ファイルに <div> 要素を追加し、コンテンツを追加します。

<記事id="記事">
  <h3>CSS トランジションを使用して高さを変更することで要素を展開したり折りたたんだりする</h3>
  <p>Lorem ipsum、痛みはエリートのアディピス中毒者によってもたらされました。一時的に症状が現れ、その後、責任を問われました。完全に元に戻ったため、通常の生活に戻ることができず、法的措置が取られました。</p>

  <p> lorem ipsum dolor sit amet adipisicing elit、ab doloribus optio。エクササイズのCommodi reiciendis culpa optio aliquam incidunt、ab sapiente dignissimos、sit deleniti boluptatibus animi repudiandae 、nisi ullam boluptatum odio non eum vel vel dolorum dolorum adipisci culpa

  <p> lorem ipsum dolor sit amet adipisicing elit、ab doloribus optio。エクササイズのCommodi reiciendis culpa optio aliquam incidunt、ab sapiente dignissimos、sit deleniti boluptatibus animi repudiandae 、nisi ullam boluptatum odio non eum vel vel dolorum dolorum adipisci culpa

  <p> lorem ipsum dolor sit amet adipisicing elit、ab doloribus optio。エクササイズのCommodi reiciendis culpa optio aliquam incidunt、ab sapiente dignissimos、sit deleniti boluptatibus animi repudiandae 、nisi ullam boluptatum odio non eum vel vel dolorum dolorum adipisci culpa
</記事>
<button id="seeMoreBtn">もっと見る</button>

CSS スタイルは次のとおりです。

記事 {
  最大幅: 800px;
  高さ: 300px;
  オーバーフロー-y: 非表示;
}

/* ボタンがクリックされたときにこのクラスを追加します */
記事.extended {
  高さ: 628px;
}

ボタン {
  パディング: .6rem;
}

JavaScript は次のとおりです。

定数seeMore = document.getElementById('seeMoreBtn')
定数記事 = document.getElementById('記事')

seeMore.addEventListener('click', () => {
  article.classList.toggle('拡張')

  const 拡張 = article.classList.contains('拡張')
  if (拡張) {
    seeMore.innerHTML = 'コンテンツを折りたたむ'
  } それ以外 {
    seeMore.innerHTML = 'もっと見る'
  }
})

ボタンがクリックされたときにコンテンツがスムーズに上下にスライドできるように、記事に CSS トランジション プロパティを追加します。

記事 {
  最大幅: 800px;
  高さ: 300px;
  オーバーフロー-y: 非表示;
  遷移: 高さ 0.4 秒の線形;
}

これを記事に適用すると、スムーズに上下にスライドできることがわかります。シンプルで便利ですが、この方法には制限があります。以下で見てみましょう。

制限

この制限は、高さがわかっているかどうかです。上記の例では、記事の高さが明確にわかっており、非常にうまく機能しますが、動的なコンテンツを扱う場合、要素の高さはわかりません。また、画面サイズやその他の手段によって高さが変わることもあります。
実際、解決策は非常に簡単です。動的コンテンツの場合、要素の高さを auto に設定する必要があります。こうすることで、要素の高さの増減が適応されます。しかし、別の問題が発生します。要素の高さが自動に設定されている場合、CSS トランジションは機能しません。
幸いなことに、JavaScript をさらに使用しなくてもこの問題を解決する方法があります。

解決

解決策は、height プロパティの代わりに max-height プロパティを変換することです。まず、要素が到達できる最大の高さを見積もる必要があります。次に、要素が拡大するときに、要素の max-height を推定値よりも大きく設定します。
height プロパティを max-height に変更します。

記事 {
    最大幅: 800px;
    最大高さ: 300px;
    オーバーフロー-y: 非表示;

    /* 高さに合わせて遷移時間を増やす */
    遷移: 最大高さ 0.7 秒線形;
}

記事.展開{
    最大高さ: 1500px;
}

この方法ではアニメーションが機能し、必要な効果が得られます。必要な効果に応じて遷移時間を調整する必要がある場合があります。

CSSトランジションの高さを変更して要素を展開したり折りたたんだりする方法についての記事はこれで終わりです。CSS高さを使用した要素の展開と折りたたみの詳細については、123WORDPRESS.COMの以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも123WORDPRESS.COMをよろしくお願いいたします。

<<:  指定されたIEブラウザのレンダリング方法の詳細な理解

>>:  Centos7 で NIS を構成する詳細な手順

推薦する

Vueプロジェクトでのトークン検証ログイン(フロントエンド部分)

この記事の例では、Vueプロジェクトでのトークン検証ログインの具体的なコードを参考までに共有していま...

Nginx でアクセス頻度、ダウンロード速度、同時接続数を制限する方法

1. アクセス頻度、同時接続、ダウンロード速度を制限するために使用されるモジュールと命令の概要ngx...

Vueはビデオ再生を実装するためにビデオタグを使用します

この記事では、ビデオタグを使用してビデオ再生を実装するVueの具体的なコードを参考までに共有します。...

Linuxのseqコマンドを使用して数字のシーケンスを生成します(推奨)

Linux の seq コマンドは、数字のリストを非常に高速に生成でき、使いやすく柔軟性に優れてい...

MySQLの半同期の詳細な説明

目次序文MySQL マスタースレーブレプリケーションMySQL でサポートされているレプリケーション...

Dockerコンテナのエクスポートとインポートの例

目次DockerコンテナのエクスポートDockerコンテナのインポ​​ートこの記事では主に、コンテナ...

ウェブデザイン:大量の素材の正確な配置と使用

3回の暗記により、大量の資材の正確な場所と目的を記憶でき、その使いやすさが向上します。 これは単なる...

Docker が elasticsearch を起動するときのメモリ不足の問題と解決策

質問Docker が elasticsearch をインストールして起動するときにメモリが不足するシ...

...

MySQL 制約の種類と例

制約制約によりデータの整合性と一貫性が確保される制約はテーブルレベルの制約と列レベルの制約に分けられ...

一般的な Linux ディストリビューションのミラーソース構成の概要

最近 Linux を研究していて、いくつかの Linux ディストリビューションを試してみましたが、...

ウェブページ作成の基本宣言文書型記述(DTD

CSS レイアウトを使用して WEB 標準に準拠した Web ページを作成することは、jb51.ne...

Excel ファイルを MySQL データベースにインポートする方法

この記事では、ExcelファイルをMySQLデータベースにインポートする方法を参考までに紹介します。...

JavaScript でドラッグ可能なプログレスバーを実装する

この記事では、ドラッグ可能なプログレスバーを実装するためのJavaScriptの具体的なコードを参考...

Linux周辺ファイルシステムのカスタマイズ方法

序文一般的に、Linux システムについて話すときは、Linux カーネルと GNU プロジェクトに...