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

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

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

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

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

CSS

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

Q&A

解決済

1回答

3004閲覧

アンカーリンクの位置と、スクロール挙動がおかしい問題をどうにか解決したい

nomura02

総合スコア133

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

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

CSS

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

0グッド

0クリップ

投稿2021/03/22 06:29

お忙しいところすみません!!

前提・実現したいこと

文中にcodepenのcodeがあります。

モーダルで画面を切り替えたときに、
☆切り替える前の画面がうごかないようにしたい。
☆正しいところにアンカーリンクがうごいてほしい
☆スクロールしたときにちゃんと上までスクロールされてほしい。
です。

現在、
・animatedModal.js
をつかって、任意の画面に切り替え
・スクロール時のアニメ(imagesLoaded)
をつかって、背景画像のスクロールにパララックスのような効果
・スムーススクロール
をつかって、アンカーリンクでの移動をなめらかに
しています。

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

animatedModal.jsで、画面を切り替えると、
モーダルにきりかわるときにもといたところにいてくれず、スクロールが勝手に下に動いてしまうのと、
TOPの上まで、スクロールが出来ず途中で止まってしまう
現象がおきております。

animatedModal.jsは、何もつけない状態なら、スクロールが勝手に下に動くなんていう挙動は起こさなかったので、
あとからつけたしたなにかの影響でそうなっているのですが、三日くらいかけても解消されず困り果ててしまいました。

いろいろ、実験してみたところ、現状は、内容物と、内容物のマージンが現在の長さになると、
この現象が起こり、
内容物を極端に少なくすると、この現象は発生しないということは分かりました。
しかしコンテンツを減らすこともできませんし、Magineやパディングもつけたいです。

該当のソースコード

コードペン

今完成に近い状態でここに載せるにはcodeがめちゃくちゃ長く、
しかし載せる用に削ると、問題が解消されてしまうので、
試験的にこんな感じになってるというのを作ってみました↑
実際は、ここまでにひどくないのですが、伝えたいことは、

  • codepenにある「ここを押して見てください」ボタンを押すと、animatedModal.jsがうごいてくれて、

内容物がモーダルとして、表示されます。しかし、うしろで、勝手にモーダルじゃないメインのほうが、動き始めて、戻る頃には、もといたところではない場所に、勝手に動いてしまっています。

  • さらに、画面がoverflow:hiddenのような状態で、

スクロールをしてメインビジュアルに戻ろうとすると、うごきません。
実際のコードでは、ここまでガチガチに動かないわけではないのですが、いずれにせよ、
スクロールをしてメインビジュアルに戻ろうとすると、500pxくらい、上にスクロールが出来ず、全画面でメインビジュアルにもどるには、
右横にある↓これが、一応作ったpagenationなのですが、これを押すほかありません。
これじゃめちゃめちゃ使いにくい!!!
イメージ説明

とにかくanimatedModal.jsで戻ってきたあとの挙動がおかしいのです。

試したこと

多分、overfllow関係と、アンカーリンクの先のMagineとかパディングのせいでは?と思い、
いろいろやってみました。
いろいろやってみて、
☆切り替える前の画面がうごかないようにしたい。⇒原因分からず
☆正しいところにアンカーリンクがうごいてほしい⇒遅延読み込みを画像に設定しているため高さががたがたするのが原因だと思われます
☆スクロールしたときにちゃんと上までスクロールされてほしい。⇒原因わからず
です。

  • 挙動だけはうまくいく↑上記が全部解消されるとき⇒各sectionにパディングやmarginをつけないとき。コンテンツの内容が少ない時。でもこれだとみちみちで醜くて困る
  • JSファイルに記載しているoverfllow系でhiddenになってるものなどを消してみる⇒解消されず
  • 画像を遅延読み込みしているので、それを無視するcodeをJSに書く⇒アンカーリンクがずれる問題もあったのですがこれはこのcode↓でアンカーリンクずれる問題は解消されましたが、スクロールができない問題は解消されませんでした。

JS

1$('a[href^="#"]').click(function(e) { 2 var href = $(this).attr("href"); 3 var target = $(href == "#" || href == "" ? 'html' : href); 4 var position = target.offset().top; 5 6 $.when( 7 $("html, body").animate({ 8 scrollTop: position 9 }, 1600, "swing"), 10 e.preventDefault(), 11 ).done(function() { 12 var diff = target.offset().top; 13 if (diff === position) { 14 } else { 15 $("html, body").animate({ 16 scrollTop: diff 17 }, 10, "swing"); 18 } 19 }); 20});
  • 固定ヘッダー分のずれをヘッダーの高さ分解消するテクニック

⇒ロゴとpagenationを固定してますが、帯状で固定していないのと、ヘッダー分どころではない部分が見えなくなっており、腑に落ちず…変化なく…

  • padding-topで固定ヘッダーの分だけ上に上げつつ、margin-topのマイナス指定で相殺するテクニック

⇒変化なく。。。

・モーダルを閉じ戻ってきた時に、スクロール出来ない部分が発生してしまいpagenationのアンカーリンクでしか上にいけないのは何故なのか。
・モーダルを閉じ戻ってきた時に、
・余白をつけたりコンテンツを増やすととそのぶんなのかはっきりとは不明ですがアンカーリンクがずれたり、勝手にスクロールされたりスクロール出来なかったりという致命的な諸問題をなんとかしたいです。

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

ローカル環境で開発中です。
ワードプレスはつかってないです。
Windowsです。
VScodeです。

ここにより詳細な情報を記載してください。

なにかヒントなど頂けますとほんとうに助かります!!!!
必要な情報などございましたら、随時記載させていただきます!!
宜しくお願い致します。

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

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

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

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

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

guest

回答1

0

自己解決

長々と失礼しました…
問題はモーダルのアンカーリンクとスムーススクロールの「#」が競合していたところにあり、
モーダルをdata属性で指定することで解決いたしました。

投稿2021/03/23 05:55

nomura02

総合スコア133

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問