teratail header banner
teratail header banner
質問するログイン新規登録

質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.30%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

1回答

443閲覧

最後の要素が重なった場所で固定したい

tsl56

総合スコア3

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

1クリップ

投稿2024/11/21 07:28

編集2024/11/21 12:45

0

1

実現したいこと

GSAPのScrollTriggerとScrollToを使って要素が重なる表現を実現したのですが、最後の要素が重なったらその場所で固定をしたいのですが、うまく実現できません。

前提

Sectionの中で終わらせたいのですが、3枚目の要素が重なってもスクロールと同時に動き次のSectionにはみ出てしまいます。

発生している問題・エラーメッセージ

エラーメッセージ

該当のソースコード

JavaScript

1gsap.registerPlugin(ScrollTrigger, ScrollToPlugin); 2 3let timeln = gsap.timeline({ 4 scrollTrigger: { 5 trigger: ".cards", 6 pin: true, 7 anticipatePin: 1, 8 pinSpacing: true, 9 start: "left-=120px left", 10 end: "bottom top", 11 scrub: 1, 12 markers: true, 13 } 14}); 15 16timeln.addLabel('card1'); 17timeln.to('.cards-item1', { 18 xPercent: 0, 19 opacity: 1 20}); 21 22timeln.from('.cards-item2', { 23 xPercent: 75, 24 opacity: 0 25}); 26timeln.addLabel("card2"); 27 28timeln.to(".cards-item1", { 29 scale: 0.95, 30 xPercent: -0.5, 31 opacity: 0.5 32}, "-=0.3"); 33 34timeln.to('.cards-item2', { 35 xPercent: 0, 36 opacity: 1 37}); 38 39timeln.from('.cards-item3', { 40 xPercent: 75, 41 opacity: 0 42}); 43timeln.addLabel('card3'); 44 45timeln.to(".cards-item2", { 46 scale: 0.98, 47 xPercent: -0.4, 48 opacity: 0.6 49}, "-=0.3"); 50 51timeln.to(".cards-item3", { 52 xPercent: 0, 53 opacity: 1, 54});

試したこと

3つ目の要素に対してScrollTriggerを作りましたが、途中で止まったりと思う様な動きになりませんでした

補足情報(FW/ツールのバージョンなど)

こちらにコードを載せました。
https://github.com/sayuri-tanimoto/test.git

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2024/11/21 07:48

現状のソースを動作が確認できるサイトにアップできませんか? そのうえでどこの部分をどう変更したいか図示できませんか?
Lhankor_Mhy

2024/11/21 09:13

ご提示のコードを試してみましたが、要素が重なることはありませんでした。 ご提示いただいていない部分に原因がありそうです。
Lhankor_Mhy

2024/11/21 09:18 編集

URLが間違っているようですね。→編集を確認
guest

回答1

0

いろいろな原因がありそうですが、ひとつだけ。

css

1.card-wrapper { 2 display: flex; 3 align-items: center; 4 width: 100%; 5 height: 100%; 6 gap: 40px; 7 padding: 45px; 8 border-radius: 4px; 9 background: #BAA0A01A; 10 backdrop-filter: blur(10px); 11 will-change: blur; 12}

となっており、box-sizingがデフォルトなので、パディングを加えると親要素をはみ出します。
ですので、たとえ.card-itemが枠内に収まっていても中身がはみ出すことになります。
スクロールアニメーションを作る前に、まずはその辺りから丁寧に作り直してみてはどうでしょうか。

投稿2024/11/21 09:35

Lhankor_Mhy

総合スコア37460

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Lhankor_Mhy

2024/11/21 09:56

あとは、topで位置指定してるのをbottomにすればわりといけるのではないでしょうか?
tsl56

2024/11/21 10:44

ありがとうございます。 作っているコードでは、下記CSSを記載していますが、そこから見直す方がいいのでしょうか。 *, *::before, *::after { box-sizing: border-box; }
Lhankor_Mhy

2024/11/21 11:04

なるほど、実際のコードとは異なるコードをご提示されているのですね。 では、効果的な回答を得るのは難しいかもしれないですね。
Lhankor_Mhy

2024/11/22 02:09

質問の編集拝読。 そちらのコードでしたら、上記の通り、topで位置指定してるのをbottomに変えるだけで、.cardsの中に納まると思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.30%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問