純粋な CSS を使用してハロウィーン トグル コントロールを実装する方法 (ソース コードが添付されています)

不言
リリース: 2019-10-31 17:50:52
転載
3094 人が閲覧しました

この記事の内容は、純粋な CSS を使用してハロウィン トグル コントロールを実装する方法に関するものです (ソース コードが添付されています)。必要な方は参考にしていただければ幸いです。

エフェクトのプレビュー

純粋な CSS を使用してハロウィーン トグル コントロールを実装する方法 (ソース コードが添付されています)

ソースコードのアドレス

https://github.com/shanyuhai123 /learnCSS/tree/master/0159-halloween-switcher

コード解釈

コンテナを定義

halloween-switchercheckboxを使用して切り替えます。

<section>
  <input>
  <label>
    <div></div>
    <div></div>
  </label>
</section>
ログイン後にコピー
フォントの導入と中央表示:

@import url('https://fonts.googleapis.com/css?family=Kodchasan');

* {
  font-family: 'Kodchasan';
}

html {
  font-size: 20px;
}

body {
  width: 100vw;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #081219;
  overflow: hidden;
}
ログイン後にコピー
実際のコンテナの設定

label サイズ

.halloween-label {
  width: 30rem;
  height: 10rem;
  border: 3px solid #E56D48;
  border-radius: 10rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  position: relative;
}
ログイン後にコピー
2 つのコンテナの色を追加

html {
  --pumpkin-color: #E56D48;
  --vampire-color: #4D7C99;
}
ログイン後にコピー
定義

pumpkin-containervampire-container コンテナとテキスト

.halloween-input ~ .halloween-label::before,
.halloween-input:checked ~ .halloween-label::before {
  position: absolute;
  font-size: 2.5rem;
  text-transform: uppercase;
}
.halloween-input ~ .halloween-label::before {
  content: 'Pumpkin';
  color: var(--pumpkin-color);
  left: 70%;
  transform: translateX(-70%);
}
.halloween-input:checked ~ .halloween-label::before {
  content: 'Vampire';
  color: var(--vampire-color);
  left: 25%;
  transform: translateX(-25%);
}

.halloween-input ~ .halloween-label .pumpkin-container,
.halloween-input ~ .halloween-label .vampire-container {
  width: 9.5rem;
  height: 9.5rem;
  border-radius: 50%;
  position: absolute;
  left: 0.25rem;
  overflow: hidden;
}
.halloween-input ~ .halloween-label .pumpkin-container {
  background-color: var(--pumpkin-color);
  filter: opacity(1);
}
.halloween-input ~ .halloween-label .vampire-container {
  background-color: var(--vampire-color);
  filter: opacity(0);
}
.halloween-input:checked ~ .halloween-label .pumpkin-container {
  left: calc(100% - 0.25rem);
  transform: translateX(-100%);
  filter: opacity(0);
}
.halloween-input:checked ~ .halloween-label .vampire-container {
  left: calc(100% - 0.25rem);
  transform: translateX(-100%);
  filter: opacity(1);
}
ログイン後にコピー
Add

labelコンテナのカラーグラデーション

.halloween-label {
  border: 3px solid var(--label-border-color);
  transition: .5s ease-in-out;
}
.halloween-label {
  --label-border-color: var(--pumpkin-color);
}
.halloween-input:checked ~ .halloween-label {
  --label-border-color: var(--vampire-color);
}
ログイン後にコピー

pumpkin-containervampire-container コンテナとテキスト

アニメーション効果

.halloween-input ~ .halloween-label::before,
.halloween-input:checked ~ .halloween-label::before {
  transition: .5s ease;
}
.halloween-input ~ .halloween-label .pumpkin-container,
.halloween-input ~ .halloween-label .vampire-container {
  transition: .5s ease;
}
ログイン後にコピー
最初に描画

pumpkin、完了 Pumpkin-container

<p>
  </p><p></p>
  <p></p>
ログイン後にコピー
新しい肌色

html {
  --pumkin-pulp-color: #330A0F;
}
ログイン後にコピー
ペイント

pumpkinpumpkin__目と鼻

擬似目を描く要素

.pumpkin__eyes-n-nose {
  position: absolute;
  top: 20%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0.8rem 1.6rem 0.8rem;
  color: var(--pumpkin-color);
  border-bottom-color: var(--pumkin-pulp-color);
  background-color: var(--pumkin-pulp-color);
}
.pumpkin__eyes-n-nose::before,
.pumpkin__eyes-n-nose::after {
  content: '';
  position: absolute;
  width: 1rem;
  height: 1rem;
  background-color: var(--pumkin-pulp-color);
  border-radius: 50%;
  top: 0.5rem;
  left: 0;
}
.pumpkin__eyes-n-nose::before {
  margin-left: -3.25rem;
}
.pumpkin__eyes-n-nose::after {
  margin-left: 2.25rem;
}
ログイン後にコピー
Painting

pumpkin ofpumpkin__mouth-n-teeths

歯を描く疑似要素

.pumpkin__mouth-n-teeths {
  position: absolute;
  width: 6.5rem;
  height: 3.25rem;
  bottom: 10%;
  background-color: var(--pumkin-pulp-color);
  border-radius: 0 0 6.5rem 6.5rem;
}
.pumpkin__mouth-n-teeths::before,
.pumpkin__mouth-n-teeths::after {
  content: '';
  position: absolute;
  height: 0.75rem;
  width: 1rem;
  background-color: var(--pumpkin-color);
}
.pumpkin__mouth-n-teeths::before {
  top: 0;
  left: 1.25rem;
}
.pumpkin__mouth-n-teeths::after {
  height: 1rem;
  bottom: 0;
  right: 1.25rem;
}
ログイン後にコピー
次に

vampire を描画して完成 vampire-container

<p>
  </p><p></p>
  <p>
    </p><p></p>
    <p></p>
  
ログイン後にコピー
擬似要素を使用して

vampire-container

.vampire-container::before,
.vampire-container::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #c2def2;  /* face color */
  border-radius: 45% 45% 0 0;
  top: 0.75rem;
}
.vampire-container::before {
  left: -4rem;
}
.vampire-container::after {
  right: -4rem;
}
ログイン後にコピー
## の顔を描画します疑似要素の描画 吸血鬼__目

<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">.vampire__eyes {   top: 20%;   position: absolute;   z-index: 1; } .vampire__eyes::before, .vampire__eyes::after {   content: '';   position: absolute;   width: 1rem;   height: 1rem;   background-color: #d63e49; /* eye-color */   border-radius: 50%;   top: 0.5rem;   left: 0; } .vampire__eyes::before {   margin-left: -3.25rem; } .vampire__eyes::after {   margin-left: 2.25rem; }</pre><div class="contentsignin">ログイン後にコピー</div></div>描画

吸血鬼__口

<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">.vampire__mouth {   position: absolute;   width: 6.5rem;   height: 3.25rem;   background-color: var(--pumkin-pulp-color);   bottom: 10%;   border-radius: 0 0 6.5rem 6.5rem;   display: flex;   justify-content: center;   overflow: hidden;   z-index: 1; }</pre><div class="contentsignin">ログイン後にコピー</div></div>描画

吸血鬼__歯

前歯、疑似要素の描画 歯<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">.vampire__teeths {   position: absolute;   width: 100%;   height: 1rem;   background-color: #fffae6;   top: -1px; } .vampire__teeths::before, .vampire__teeths::after {   content: '';   position: absolute;   width: 0;   height: 0;   color: transparent;   border-style: solid;   border-width: 0.65rem 0.375rem 0 0.375rem;   border-top-color: #fffae6;   top: 0.95rem; } .vampire__teeths::before {   left: 1rem; } .vampire__teeths::after {   right: 1rem; }</pre><div class="contentsignin">ログイン後にコピー</div></div>描画

吸血鬼__舌

<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">.vampire__tongue {   position: absolute;   width: 3.5rem;   height: 1.75rem;   background-color: #d63e49;   bottom: -0.75rem;   border-radius: 3.5rem 3.5rem 0 0; }</pre><div class="contentsignin">ログイン後にコピー</div></div>次に、

チェックボックスを非表示にします

<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">.halloween-input {   display: none; }</pre><div class="contentsignin">ログイン後にコピー</div></div>笑顔のアニメーションを追加します

smile

# #

.vampire__teeths {
  animation: smile 2s ease-in-out infinite;
}
.vampire__tongue {
  animation: smile 3s ease-in-out infinite;
}
@keyframes smile {
  50% {
    transform: scaleY(1.5);
  }
}
ログイン後にコピー

以上が純粋な CSS を使用してハロウィーン トグル コントロールを実装する方法 (ソース コードが添付されています)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:segmentfault.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート