ホームページ ウェブフロントエンド htmlチュートリアル Pure CSS でアンカーポイントクリック時のスムーズな切り替え効果を実現_html/css_WEB-ITnose

Pure CSS でアンカーポイントクリック時のスムーズな切り替え効果を実現_html/css_WEB-ITnose

Jun 24, 2016 am 11:30 AM

Pure CSS は、アンカーポイントをクリックしたときのスムーズな切り替え効果を実現します

22.50 注: ちょっと間違っているようです o(╯□╰)o 今は読まないでください
時々、関数を実装したいことがありますが、ページの作成など スクロール バーはありませんが、より多くのものを保持できます。この時点では、コンテナーに overflow: hidden を設定し、アンカー ポイントを使用してクリックしてページを切り替える効果を実現します。表示されるコンテンツを制御します)。ただし、アンカー ポイントを介して指定されたコンテンツにジャンプする場合、トランジション効果がなく、ターゲット ポイントへのジャンプが非常に突然になるという欠点があります。もちろん、JS または jQuery を使用して、必要な動的切り替え効果を実現することもできます。このカテゴリには多数の記事があるため、ここでは詳しく説明しません。

ただし、github の個人ホームページ (ホームページのみ、つまり username.github.io) など、一部の個人ホームページでは、この時点で JS スクリプトの実行が禁止されています。アンカーポイントをクリックしたら、どうすればいいですか?

フロントエンド初心者で申し訳ありませんが、長い間考えましたが、解決策が思いつかなかったので、Baidu と Google に頼りました。

その後、チェック属性を備えたラジオを使用するなど、いくつかの方法を見つけました。この方法については、MOOC にも特別なチュートリアルがあります。

しかし、ラジオを挿入せずに対応する効果を達成することは可能ですか? 答えは「はい」です。

つまり、:target 疑似クラスを使用すると、このセレクターで現在のアクティビティのアンカー ポイントを選択でき、この属性を使用して目的の効果を実現できます。

コードは次のとおりです:

<a href="#tag1">Tag1</a><a href="#tag2">Tag2</a><a href="#tag3">Tag3</a><div id="container">  <div id="tag1"></div>  <div id="tag2"></div>  <div id="tag3"></div></div>
ログイン後にコピー

div{  width: 100px;  height: 100px;  border-radius: 50%;}#container{  margin-top: 10px;  outline: 1px solid red;  position: relative;}#tag1,#tag2,#tag3{  transition: all ease-out .2s;  position: absolute;  top:0  left:0;  right:0;  bottom:0;  opacity: 0;  }#tag1{  background: #f66;  opacity: 1;  z-index: 1;}#tag2{  background: orange;}#tag3{  background: gray;}#container>div:target{  z-index: 1000;  opacity: 1;}
ログイン後にコピー

デモを見る

上記の例は、絶対位置、Z インデックス、透明度によって達成される動的効果です。まずすべての要素の不透明度を 0 に設定し、次に最初の要素をデフォルトで表示するために、最初の要素の不透明度を 1、z インデックスを 1 に設定します。次にクリックして動的切り替えを実行します。

実際、私が最初に試したのは、#container に overflow: hidden; を設定し、その子要素に height:100%; を設定してから、margin-top を負のパーセンテージ値に設定することでした。ターゲットはやっぱり下から上へ上がる感じか、上から下へ落ちる感じの方が好きです。 。 。ただし、実装プロセス中に小さな問題が発生しました。つまり、Tag2 と Tag3 が相互に切り替わるときに、途中までしか移動せず、overflow: hidden を削除すると、期待どおりの効果が表示されます。問題のあるデモ

その後、解決策を考えました。それは、コンテナを div でラップし、この要素に overflow: hidden を設定し、コンテナのオーバーフローを削除し、高さをその子要素の高さに設定することです。 . これで正常に表示されます。デモはここにあります。

解決策は見つかりましたが、問題のデモの奇妙な動作がよくわかりません。ご存知の方がいらっしゃいましたら、教えてください。ありがとうございます。

参照:
stackoverflow - 純粋な CSS スクロール効果

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

&lt; Progress&gt;の目的は何ですか 要素? &lt; Progress&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:34 PM

この記事では、HTML&lt; Progress&gt;について説明します。要素、その目的、スタイリング、および&lt; meter&gt;との違い要素。主な焦点は、&lt; Progress&gt;を使用することです。タスクの完了と&lt; Meter&gt; statiの場合

&lt; datalist&gt;の目的は何ですか 要素? &lt; datalist&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:33 PM

この記事では、HTML&lt; Datalist&GT;について説明します。オートコンプリートの提案を提供し、ユーザーエクスペリエンスの改善、エラーの削減によりフォームを強化する要素。

&lt; meter&gt;の目的は何ですか 要素? &lt; meter&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:35 PM

この記事では、html&lt; meter&gt;について説明します。要素は、範囲内でスカラーまたは分数値を表示するために使用され、Web開発におけるその一般的なアプリケーション。それは差別化&lt; Meter&gt; &lt; Progress&gt;およびex

ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? Mar 20, 2025 pm 05:56 PM

この記事では、モバイルデバイスのレスポンシブWebデザインに不可欠なViewportメタタグについて説明します。適切な使用により、最適なコンテンツのスケーリングとユーザーの相互作用が保証され、誤用が設計とアクセシビリティの問題につながる可能性があることを説明しています。

&lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? &lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? Mar 20, 2025 pm 06:05 PM

この記事では、&lt; iframe&gt;外部コンテンツをWebページ、その一般的な用途、セキュリティリスク、およびオブジェクトタグやAPIなどの代替案に埋め込む際のタグの目的。

HTMLは初心者のために簡単に学ぶことができますか? HTMLは初心者のために簡単に学ぶことができますか? Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTML、CSS、およびJavaScriptの役割:コアの責任 HTML、CSS、およびJavaScriptの役割:コアの責任 Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTMLでの開始タグの例は何ですか? HTMLでの開始タグの例は何ですか? Apr 06, 2025 am 12:04 AM

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

See all articles