ホームページ >ウェブフロントエンド >jsチュートリアル >ケアされたアニメーションHTML CSS
`<
@property --x {
構文: "
初期値: 35%;
継承: false;
}
@property --shine {
構文: "
初期値: 透明;
継承: false;
}
@property --shadow-strength {
構文: "
初期値: 0%;
継承: false;
}
:root {
--h: 240;
--s: 97%;
--l: 50%;
--surface-1: hsl(var(--h) var(--s) calc(var(--l) 4%));
--surface-2: hsl(var(--h) var(--s) calc(var(--l) 8%));
--surface-3: hsl(var(--h) var(--s) calc(var(--l) 12%));
--text: hsl(var(--h) var(--s) 96%);
--text-alt: hsl(var(--h) var(--s) 85%);
--shadow-color: var(--h) var(--s) 15%;
--影の強さ: 1%;
--shadow: 0 -2px 5px 0 hsl(var(--shadow-color) /
calc(var(--shadow-strength) 2%)),
0 1px 1px -2px hsl(var(--shadow-color) / calc(var(--shadow-strength) 3%)),
0 2px 2px -2px hsl(var(--shadow-color) / calc(var(--shadow-strength) 3%)),
0 5px 5px -2px hsl(var(--shadow-color) / calc(var(--shadow-strength) 4%)),
0 9px 9px -2px hsl(var(--shadow-color) / calc(var(--shadow-strength) 5%)),
0 16px 16px -2px hsl(var(--shadow-color) / calc(var(--shadow-strength) 6%));
--スペース: 1rem;
}
body {
カラー: var(--text);
背景: var(--surface-1);
パディングインライン: var(--space);
フォントサイズ: 1.125rem;
行の高さ: 1.4;
フォントファミリー: システム UI、サンセリフ;
フォントの太さ: 300;
}
メイン {
表示: グリッド;
ギャップ: 35vh;
}
.page-section {
コンテナタイプ: インラインサイズ;
表示: グリッド;
ギャップ: var(--space);
インラインサイズ: min(var(--max, 30rem), 100%);
margin-inline: auto;
}
.page-footer {
margin-block-start: 50vh;
text-align: center;
パディング: 2rem;
h2 {
表示: グリッド;
}
h2::before {
コンテンツ: "";
表示: ブロック;
幅: 1px;
高さ: 3レム;
margin-block-end: 0.5rem;
margin-inline: auto;
背景: var(--surface-3);
}
}
.icon {
幅: 2.5rem;
高さ: 自動;
}
.icon-sm {
幅: 1.5rem;
カラー: var(--text-alt);
}
.text-label {
font-size: 0.8em;
フォントの太さ: 500;
文字間隔: 0.01em;
}
.author {
text-align: end;
}
.cluster {
表示: flex;
align-items: center;
ギャップ: 1rem;
}
.page-headline {
---_マージン: 30vh;
マージンブロック開始: var(--_margin);
text-align: center;
&::after {
コンテンツ: "";
表示: ブロック;
幅: 1px;
高さ: var(--_margin);
margin-block-start: 0.8rem;
margin-inline: auto;
背景: var(--surface-3);
}
}
box-gleam {
---_gleam: 線形グラデーション(
115 度、
透明度 40%、
var(--surface-3),
透明度 70%
)
var(--x) 0 / 600% 100% パディングボックス;
--_gleam-cover: 放射状グラデーション(
中心の円、
var(--surface-1),
透明
)
パディングボックス;
--_cover: 線形グラデーション(var(--surface-1), var(--surface-1)) パディングボックス;
--_shine: 円錐勾配(
var(--angle) から、
var(--shine)、
透明 20% 80%、
var(--shine)
)
ボーダーボックス;
---_edges: 線形グラデーション(
155 度、
var(--surface-3),
var(--surface-2) 20% 80%、
var(--surface-3)
)
ボーダーボックス;
表示: グリッド;
ギャップ: var(--space);
位置: 相対;
パディング: 1.6rem;
境界半径: 0.8rem;
境界線: 1 ピクセルの実線透明;
box-shadow: var(--shadow);
背景: var(--gleam-cover)、var(--gleam)、var(--_cover)、var(--_shine)、
var(--_edges);
}
@supports (アニメーションタイムライン: view()) {
box-gleam {
アニメーション: リニア両方;
アニメーション名: 輝き、輝き、影;
アニメーション タイムライン: view();
アニメーション範囲: カバー -10% カバー 100%、エントリ 0% カバー 65%、
入口 0% 出口 150%;
}
}
@media (prefers-reduced-motion:reduce) {
box-gleam {
アニメーション: なし!重要;
}
}
@keyframes gleam {
{
から
--角度: -1turn;
--x: 0%;
}
{
へ
--角度: 1turn;
--x: 100%;
}
}
@keyframes シャドウ {
から、
{
へ
box-shadow: なし;
}
50%、
65% {
box-shadow: var(--shadow);
}
}
@keyframes 輝き {
0%、
45% {
--shine: 透明;
}
80% {
--shine: hsl(var(--h) var(--s) calc(var(--l) 38%));
}
}
弁当グリッド {
表示: グリッド;
ギャップ: var(--space);
@container (インラインサイズ > 35rem) {
弁当グリッド {
グリッド テンプレート列:repeat(var(--col-count, 3), 1fr);
グリッド テンプレート行:repeat(var(--row-count, 3), auto);
<box-gleam> <blockquote> <p>Fantasy is a necessary ingredient in living, it's a way of looking at life through the wrong end of a telescope.</p> </blockquote> <p class="author text-label">Dr. Seuss</p> </box-gleam> <box-gleam> <blockquote> <p>A day without sunshine is like, you know, night.</p> </blockquote> <p class="author text-label">Steve Martin</p> </box-gleam> <box-gleam> <blockquote> <p>I refuse to answer that question on the grounds that I don't know the answer</p> </blockquote> <p class="author text-label">Douglas Adams</p> </box-gleam> <box-gleam> <blockquote> <p>Whatever the problem, be part of the solution. Don’t just sit around raising questions and pointing out obstacles.</p> </blockquote> <p class="author text-label">Tina Fey</p> </box-gleam> <box-gleam> <blockquote> <p>Never memorize something that you can look up.</p> </blockquote> <p class="author text-label">Albert Einstein</p> </box-gleam> <box-gleam> <blockquote> <p>It’s no use going back to yesterday, because I was a different person then.</p> </blockquote> <p class="author text-label">Lewis Carroll</p> </box-gleam>
<svg class="icon" aria-hidden="true" width="15" height="15" viewBox="0 0 15 15" fill="none" xmlns="http://www.w3.org /2000/svg"> <パス d="M12.3536 1.14645C12.1583 0.951184 11.8417 0.951184 11.6464 1.14645C11.4512 1.34171 11.4512 1.65829 11.6464 1.85355L12.7929 3H12C10.7037 3 9.71111 3.58423 8.87248 4.38931C8.20065 5.03427 7.59349 5.85684 6.99461 6.6682C6.86287 6.84668 6.73154 7.02462 6.6 7.2C5.10874 9.18835 3.49037 11 0.5 11C0.223858 11 0 11.2239 0 11.5C0 11.7761 0.223858 12 0.5 12C4.00963 12 5.89126 9.81165 7.4 7.8C7.54367 7.60845 7.6832 7.41962 7.81996 7.23454L7.82005 7.23443L7.82006 7.23441C8.41674 6.42695 8.96069 5.69085 9.56502 5.11069C10.2889 4.41577 11.0463 4 12 4H12.7929L11.6464 5.14645C11.4512 5.34171 11.4512 5.65829 11.6464 5.85355C11.8417 6.04882 12.1583 6.04882 12.3536 5.85355L14.3536 3.85355C14.5488 3.65829 14.5488 3.34171 14.3536 3.14645L12.3536 1.14645ZM0.5 3C3.35278 3 5.12992 4.44588 6.50548 6.06746L6.3762 6.24266C6.2483 6.4161 6.12293 6.58609 6 6.75C5.96397 6.79804 5.92798 6.84581 5.892 6.89331C4.57348 5.29306 3.02637 4 0.5 4C0.223858 4 0 3.77614 0 3.5C0 3.22386 0.223858 3 0.5 3ZM8.87248 10.6107C8.37284 10.131 7.90897 9.55314 7.45767 8.95468C7.64688 8.71693 7.82704 8.48061 8 8.25L8.08987 8.12987C8.58412 8.79402 9.05288 9.39766 9.56502 9.88931C10.2889 10.5842 11.0463 11 12 11H12.7929L11.6464 9.85355C11.4512 9.65829 11.4512 9.34171 11.6464 9.14645C11.8417 8.95118 12.1583 8.95118 12.3536 9.14645L14.3536 11.1464C14.5488 11.3417 14.5488 11.6583 14.3536 11.8536L12.3536 13.8536C12.1583 14.0488 11.8417 14.0488 11.6464 13.8536C11.4512 13.6583 11.4512 13.3417 11.6464 13.1464L12.7929 12H12C10.7037 12 9.71111 11.4158 8.87248 10.6107Z" fill="currentColor" fill-rule="evenodd" Clip-rule="evenodd"></path> </svg> <h2 class="text-label">ビートをシャッフルします</h2> </box-gleam> <h2>巻物をありがとう</h2> <br><br> <br><br> <br><br> <br><br> `
以上がケアされたアニメーションHTML CSSの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。