検索

単一要素ローダー:スピナー

CSSのみのローダーを作成することはやりがいのある課題です。魅惑的な無限のアニメーションは、常に作成するのに満足しています。 Codepenは膨大な手法を紹介していますが、この記事では、最小限のコードでシングルエレメントローダーを達成することに焦点を当てています。

私は500を超えるシングルdivローダーを開発しましたが、この4部構成のシリーズは使用された手法を共有しています。多数の例を探り、微妙な調整がどのように多様な結果をもたらし、コードがどれほど簡潔になるかを示します。

シングルエレメントローダーシリーズ:

  1. 単一の要素ローダー:スピナー -あなたはここにいます
  2. 単一要素ローダー:ドット
  3. 単一要素ローダー:バー
  4. 単一要素ローダー:3Dに進みます

この最初の記事では、共通のローダーパターンを作成します:スピニングバー。

アプローチ

単純なアプローチでは、複数の要素(この場合は9)を使用し、それぞれが親の内部でバーを表します。不透明度と変換は、紡績効果を生み出します。

ただし、私の方法では、1つの要素のみを使用しています。

<div></div>

...および10のCSS宣言:

 .loader {
  幅:150px; / *サイズを制御 */
  アスペクト比:1;
  ディスプレイ:グリッド;
  マスク:conic-勾配(22deg、#0003、#000から);
  アニメーション:1秒のステップ(8)無限をロードします。
}
。ローダ、
.loader:{前
  -_ g:線形勾配(#17177c 0 0)50%; / *ここで色を更新 */
  背景: 
    var(--_ g)/34%8%スペースなし繰り返し、
    var(-_ g)/8%34%繰り返しスペース。
}
.loader:{前
  コンテンツ: "";
  変換:回転(45DEG);
}
@KeyFramesロード{
  {transform:rotate(1turn); }
}

コードの内訳

コードは最初は珍しいように思えるかもしれませんが、表示されるよりも簡単です。まず、要素の寸法(150pxの正方形)を定義します。 aspect-ratioサイズ変更に関係なく正方形のままであることを保証します。

 .loader {
  幅:150px; / *サイズを制御 */
  アスペクト比:1; / *正方形の形状を維持 */
}

CSSローダーの場合、シングルサイズの制御値が理想的です。ここでは、幅です。すべての計算はそれに関連しています。これにより、簡単なサイズの調整が可能になります。

勾配はバーを作成します。これは最も複雑な部分です。単一の勾配が2つのバーを生成します。

背景:線形勾配(#17177c 0 0)50%/34%8%スペースなし繰り返し。

勾配は1色と2色の停止を使用して、固体色になります。サイズの幅は34%、高さは8%、中心(50%)です。 spaceキーワードは勾配を複製し、2つのバーを作成します。

仕様から:

画像は、クリップされずにバックグラウンドポジショニング領域に収まるように頻繁に繰り返され、その後、画像が領域を埋めるために間隔を空けています。最初と最後の画像は、エリアの端に触れます。

幅34%の幅は、2つのバー(3 34%> 100%)のみを許可し、ギャップ(100% - 2 34%= 32%)が残りますspaceこれらのギャップを中央に配置します。 33%から50%の幅により、間隔の少なくとも2つのバーが保証されます。

2番目の勾配を使用してさらに2つのバーを作成し、以下を作成します。

背景: 
 線形勾配(#17177c 0 0)50%/34%8%スペースなし、繰り返し、
 線形勾配(#17177c 0 0)50%/8%34%繰り返しのスペース。

CSS変数はこれを最適化します:

 -_ g:線形勾配(#17177c 0 0)50%; / *ここで色を更新 */
背景: 
 var(--_ g)/34%8%スペースなし繰り返し、
 var(-_ g)/8%34%繰り返しスペース。

これにより、4つのバーが生成されます。 CSS変数は、色の更新を簡素化します。

.loader要素とその::before 、さらに4つのバーを作成します。

 .loader {
  幅:150px; / *サイズを制御 */
  アスペクト比:1;
  ディスプレイ:グリッド;
}
。ローダ、
.loader :: before {
  -_ g:線形勾配(#17177c 0 0)50%; / *ここで色を更新 */
  背景: 
    var(--_ g)/34%8%スペースなし繰り返し、
    var(-_ g)/8%34%繰り返しスペース。
}
.loader :: before {
  コンテンツ: "";
  変換:回転(45DEG);
}

display: grid擬似要素が親の領域をカバーし、明示的な寸法の必要性を排除することを保証します。

擬似エレメントを45DEGで回転させると、残りのバーが位置します。

不透明なコントロール

フェージングトレイルを離れる単一のバーの効果はconic-gradientを備えたCSS maskを使用して達成されます。

マスク:conic-勾配(22deg、#0003、#000から);

この勾配は、徐々に透明性を時計回りに増加させます。ローダーに適用すると、フェードバーの錯覚が作成されます。各バーはマスキングのためにフェードしているように見え、さまざまな不透明度の印象を生み出します。

回転アニメーション

steps(8) (8はバーの数)を使用して、段階的なアニメーションが回転を作成します。

 .loader {
  アニメーション:3Sステップ(8)無限をロードします。
}

@KeyFramesロード{
  {transform:rotate(1turn)}
}

これにより、シングルエレメントの最小CSSローダーが完成します。サイズと色は簡単に制御できます。 A ::after追加すると、マイナーなコード調整で12のバーに拡張できます。異なる勾配と不透明なテクニックを使用して、代替の実装も可能です。

代替形状:ドット

線形勾配の代わりに放射状勾配を使用して、ドットベースのローダーを作成することも同様です。不透明度のマスキングの中心的な概念は同じままですが、形状は円です。 Safariの互換性には、勾配調整が必要になる場合があります。

さらなる例

さまざまな技術(勾配、マスク、擬似要素)を使用して、いくつかの追加のスピナーローダーが表示されています。これらは、さまざまなアプローチを理解する上での演習として機能します。

結論

単一のdiv 、勾配、擬似要素、および変数を使用すると、さまざまな紡績ローダーを作成できます。例は根本的に類似しており、軽微な変更があります。これはほんの始まりです。このシリーズでは、より高度なCSSローダーテクニックを探索します。

シングルエレメントローダーシリーズ:

  1. 単一の要素ローダー:スピナー -あなたはここにいます
  2. 単一要素ローダー:ドット
  3. 単一要素ローダー:バー
  4. 単一要素ローダー:3Dに進みます

以上が単一要素ローダー:スピナーの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
カーソルの次のレベルCSSスタイリングカーソルの次のレベルCSSスタイリングApr 23, 2025 am 11:04 AM

CSSを備えたカスタムカーソルは素晴らしいですが、JavaScriptを使用して次のレベルに物事を引き出すことができます。 JavaScriptを使用して、カーソル状態間で移行し、カーソル内に動的テキストを配置し、複雑なアニメーションを適用し、フィルターを適用できます。

Worlds Collide:スタイルクエリを使用したキーフレーム衝突検出Worlds Collide:スタイルクエリを使用したキーフレーム衝突検出Apr 23, 2025 am 10:42 AM

2025年には、互いに互いに跳ね返る要素を伴うインタラクティブなCSSアニメーションは、CSSにPongを実装する必要はありませんが、CSSの柔軟性とパワーの増加はLee&#039;の疑いを補強します。

UI効果にCSSバックドロップフィルターを使用しますUI効果にCSSバックドロップフィルターを使用しますApr 23, 2025 am 10:20 AM

CSSバックドロップフィルタープロパティを使用してユーザーインターフェイスをスタイルするためのヒントとコツ。バックドロップフィルターを複数の要素間でレイヤー化する方法を学び、それらを他のCSSグラフィカル効果と統合して、精巧なデザインを作成します。

微笑んでいますか?微笑んでいますか?Apr 23, 2025 am 09:57 AM

まあ、SVG&#039;の組み込みのアニメーション機能は、計画どおりに非推奨されることはありませんでした。確かに、CSSとJavaScriptは負荷を運ぶことができる以上のものですが、以前のようにSmilが水中で死んでいないことを知っておくのは良いことです

「かわいい」は見る人の目にあります「かわいい」は見る人の目にありますApr 23, 2025 am 09:40 AM

イェーイ、テキストワラップのジャンプを見てみましょう:サファリテクノロジーのプレビューにかなり着陸してください!しかし、それがChromiumブラウザーでの仕組みとは異なることに注意してください。

CSS-Tricks XLIIIを記録しますCSS-Tricks XLIIIを記録しますApr 23, 2025 am 09:35 AM

このCSS-Tricksアップデートは、アルマナック、最近のポッドキャスト出演、新しいCSSカウンターガイド、および貴重なコンテンツを提供するいくつかの新しい著者の追加の大幅な進歩を強調しています。

Tailwind&#039;の@Apply機能は、響きよりも優れていますTailwind&#039;の@Apply機能は、響きよりも優れていますApr 23, 2025 am 09:23 AM

ほとんどの場合、人々はTailwind&#039;の@Apply機能を紹介します。このように展示されたとき、@Applyはまったく有望な音をしません。だからobvio

私はリリースがないように感じます:正気な展開への旅私はリリースがないように感じます:正気な展開への旅Apr 23, 2025 am 09:19 AM

馬鹿のように展開することは、展開に使用するツールと複雑さの報酬と複雑さの減少との間の不一致になります。

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

メモ帳++7.3.1

メモ帳++7.3.1

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