結果のプレビュー
押してフルスクリーンプレビューへのリンクをクリックして、現在のページをプレビューする権利「プレビュー]をクリックします」ボタンをクリックします。
https://codepen.io/comehope/pen/pxLbjv
インタラクティブビデオ
このビデオでは、対話型である、あなたがビデオを編集して、コードのビデオを一時停止することができます。
クロム、サファリ、エッジオープンビューを使用してください。
https://scrimba.com/p/pEgDAM/cMV8euJ
ソースコードのダウンロード
毎日のフロントエンド戦闘シリーズ完全なソースコードはgithubのからダウンロードできます。
https://github.com/comehope/front-end-daily-challenges
コード読み取り
定義されたDOM、容器は.umbralla
二つの要素、含有.canopy
傘カバーの代表.shaft
傘。
<figure class="umbralla">
<div class="canopy"></div>
<div class="shaft"></div>
</figure>
中央揃え:
body {
margin: 0;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(skyblue, lightblue);
}
擬似要素の共通の属性を設定します:
.umbrella *::before,
.umbrella *::after {
content: '';
position: absolute;
}
傘開いた表情を描画するには。
前記コンテナのサイズは、提供されたfont-size
属性値がバックを使用する必要があり、その変数の定義:
:root {
--font-size: 10px;
}
.umbrella {
position: relative;
width: 25em;
height: 26em;
font-size: var(--font-size);
}
キャノピーのサイズを定義します。
.umbrella .canopy {
position: absolute;
width: inherit;
height: 5.5em;
top: 2.5em;
}
使用される::before
ダミー素子の天蓋上部を描画するために、この方法は、半円を描く、それを垂直方向に圧縮されます。
.umbrella .canopy::before {
width: inherit;
height: 12.5em;
background: rgb(100, 100, 100);
border-radius: 12.5em 12.5em 0 0;
transform: scaleY(0.4);
top: -4em;
}
使用::after
下半分の天蓋擬似要素を描画します:
.umbrella .canopy::after {
width: inherit;
height: 1.5em;
background-color: #333;
top: 4em;
border-radius: 50%;
}
ポール傘を描きます:
.umbrella .shaft {
position: absolute;
width: 0.8em;
height: 18em;
background-color: rgba(100, 100, 100, 0.7);
top: 5.5em;
left: calc((100% - 0.8em) / 2);
}
擬似ロッド先端の傘天蓋の上面が露出している示された要素、および天蓋動画の上部と同様の方法、半円形の第1の延伸、それを水平方向に圧縮されます。
.umbrella .shaft::before {
width: 6em;
height: 3em;
background-color: rgba(100, 100, 100, 0.7);
left: calc((100% - 6em) / 2);
top: -5.5em;
border-radius: 6em 6em 0 0;
transform: scaleX(0.1);
}
フック傘の柄を描きます:
.umbrella .shaft::after {
box-sizing: border-box;
width: 4em;
height: 2.5em;
border: 1em solid #333;
top: 100%;
left: calc(50% - 4em + 1em / 2);
border-radius: 0 0 2.5em 2.5em;
border-top: none;
}
傘を開くこの完了は、方法は、ドロールックス、閉じた傘の変形が続きます。
天蓋の最初の係合が、水平方向に圧縮され、垂直方向に延伸します。
.umbrella .canopy {
transform-origin: top;
transform: scale(0.08, 4);
}
天蓋の下半分を隠します:
.umbrella .canopy::after {
transform: scaleY(0);
}
傘を少し硬いが逆立っているため、これほど少ないの変更を追加し、翼の傾きをしてみましょう:
.umbrella {
transform: rotate(-30deg);
}
この時点で、また完成傘を閉じるときのように、我々はトグル制御にそれを置きます。
でDOM増加にcheckbox
コントロール:
<input type="checkbox" class="toggle">
<figure class="umbrella">
<!-- 略 -->
</figure>
大きな傘、傘のようにコントロールを設定し、上層に配置されました。
.toggle {
position: absolute;
filter: opacity(0);
width: 25em;
height: 26em;
font-size: var(--font-size);
cursor: pointer;
z-index: 2;
}
checkbox
傘のような、あれば指定したコントロールが選択されているように、それは傘を開いたときのような状態に対応する現在傘を閉じるときのような対応の未チェックの制御。傘が閉じ変形がいくつかの要素を取得しているので、それが開いた状態の傘が変形解除に変換されます。
傘正オーバーをしてみましょう:
.toggle:checked ~ .umbrella {
transform: rotate(0deg);
}
そして、キャノピーを開きます。
.toggle:checked ~ .umbrella .canopy {
transform: scale(1, 1);
}
再び天蓋の下半分には示しています。
.toggle:checked ~ .umbrella .canopy::after {
transform: scaleY(1);
}
最後に、いくつかの要素よりも多くの緩和効果を設定します。
.umbrella,
.umbrella .canopy,
.umbrella .canopy::after {
transition: 0.3s cubic-bezier(0.5, -0.25, 0.5, 1.25);
}
私たちは完了です。