🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

Q&A

解決済

1回答

970閲覧

スクロールしなくても、ページを開いたら要素をフェードさせたい

sofie

総合スコア2

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

0グッド

0クリップ

投稿2021/03/24 09:54

前提・実現したいこと

スクロールしなくても、ページを開いたら要素をフェードさせたい。

ページを開けた時とスクロールした時にフェードで要素が表示せれるようにしたいのですが、
ページの上部にすでに要素がある場合のみ、ページを開けても、フェードで反映される時もあれば、要素がフェードしないで空白になってしまったり、とても不安定です。ページを開けた時に、要素が上部にあってもすでにフェードで出てくるようにするには、どうしたら良いでしょうか?
どなたか詳しい方いらっしゃいましたら、教えてくださると助かります。
よろしくお願いいたします。

発生している問題

ページを開けても、フェードで反映される時もあれば、要素がフェードしないでページが空白になってしまう。

以下が試しているコードになります。

jQuery(function($) {

var effect_btm = 0;
var effect_move = 11;
var effect_time = 500;

$('.scroll-fade-row').css({ opacity: 0

});
$('.scroll-fade-row').children().each(function(){
$(this).css({
opacity: 0,
transform: 'translateY('+ effect_move +'px)',
transition: effect_time + 'ms'
});
});

$(window).on('scroll load', function(){
var scroll_top = $(this).scrollTop();
var scroll_btm = scroll_top + $(this).height();
var effect_pos = scroll_btm - effect_btm;

$('.scroll-fade-row').each( function() { var this_pos = $(this).offset().top; if ( effect_pos > this_pos ) { $(this).css({ opacity: 1, transform: 'translateY(0)' }); $(this).children().each(function(i){ $(this).delay(100 + i*200).queue(function(){ $(this).css({ opacity: 1, transform: 'translateY(0)' }).dequeue(); }); }); } });

});

});

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

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

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

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

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

guest

回答1

0

ベストアンサー

jQueryはv3系ですか?そしたら以下が当てはまるかもしれません。
https://wemo.tech/109
readyとloadの解釈が厳格になったと言うことでしょうか。。。

コード的には一番大枠の部分を消したら一応は動いたみたいですけど、
どうでしょう

var effect_btm = 0;
var effect_move = 11;
var effect_time = 500;

$(".scroll-fade-row").css({
opacity: 0
});
$(".scroll-fade-row")
.children()
.each(function () {
$(this).css({
opacity: 0,
transform: "translateY(" + effect_move + "px)",
transition: effect_time + "ms"
});
});
$(window).on("scroll load", function () {
var scroll_top = $(this).scrollTop();
var scroll_btm = scroll_top + $(this).height();
var effect_pos = scroll_btm - effect_btm;

$(".scroll-fade-row").each(function () {
var this_pos = $(this).offset().top;
if (effect_pos > this_pos) {
$(this).css({
opacity: 1,
transform: "translateY(0)"
});
$(this)
.children()
.each(function (i) {
$(this)
.delay(100 + i * 200)
.queue(function () {
$(this)
.css({
opacity: 1,
transform: "translateY(0)"
})
.dequeue();
});
});
}
});
});

投稿2021/03/24 15:26

Yusuke_m25

総合スコア74

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

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

sofie

2021/03/26 09:31

ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問