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

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

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

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

HTML

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

CSS

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

Q&A

解決済

1回答

1960閲覧

ローディング画面について

hiroki88

総合スコア66

jQuery

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

HTML

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

CSS

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

0グッド

0クリップ

投稿2019/02/14 05:40

編集2019/02/14 05:46

HTML

1<div id="loader"> 2 Loading <span id="load-text">0%</span> 3 <div id="bar"><span></span></div> 4 </div> 5 <img src="素材/robbot.jpg" alt="" />

CSS

1body{ 2 background-color: #000; 3 } 4#loader { 5 font-family: 'Marvel', sans-serif; 6 margin: 0 auto; 7 width: 300px; 8 text-align: center; 9 font-size: 25px; 10 color: #efefef; 11 margin-top: 300px; 12 display:none; 13 } 14#bar { 15 width: 300px; 16 height: 2px; 17 border:1px solid #efefef; 18 padding: 1px; 19 margin-top: 10px; 20 font-size: 1px; 21 } 22#bar span { 23 display:block; 24 width:0px; 25 height:2px; 26 background-color: #efefef; 27 } 28

jQuery

1$(function() { 2 var h = $(window).height(); 3 4 $('img').css('display','none'); 5 $('#loader').height(h).css('display','block'); 6 var count= 0; 7 8 var timer = window.setInterval(function() { 9 if (count >= 100) { 10 window.clearInterval(timer); 11 $('#loader').fadeOut('slow', function() { 12 $('img').fadeIn('slow'); 13 }); 14 } else { 15 if (count <= 100) { 16 count++; 17 $('#load-text').html(count + '%'); 18 $('#bar span').css('width', count + '%'); 19 } 20 } 21 },30) 22});

【やりたいこと】
ローディング中のみローディング画面を表示させて
ローディングが完了したらローディング画面を非表示にして
トップページを表示させたい。

また、今のプログラムだと100%になったらローディング画面がfadeOutする
ようになっているのですが、ローディング完了時に100%になってfadeOutする
プログラムにしたい。なのでローディングの量?に合わせて%が増えていくようにしたい。

今回記載してあるHTMLでいうと#loaderがローディング画面で
imgがトップページという設定です。

【困っていること】
今の時点でページのローディングが完了してから0%~100%になるプログラムが発生しているので
ローディング中に0%~100%になるプログラムを発生させるため
$(window).on('load',function () {});をvar timer = window.setInterval(function() {........});に囲んでみましたが、プログラムが起動しませんでした。
プログラミングについては素人なのでそもそもそのやり方が合ってないかもしれませんが思いつくことは試してみました。

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

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

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

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

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

m.ts10806

2019/02/14 05:43

JavaScriptのコードですがインデントが揃っていない場所があるのでそろえられた方が良いです。
hiroki88

2019/02/14 05:47

見づらくて申し訳ありませんでした。 修正してみましたのでご確認お願いします。
m.ts10806

2019/02/14 05:49

「質問で見せるため」というより「自分で見難くないかな?」というほうが気になりました。 いずれにしてもインデントきちんとなっていないとそれだけでバグの温床ですし問題の切り分けも難しくなるものですので。
guest

回答1

0

ベストアンサー

ローディング完了時に100%になってfadeOutする

なっているように見えます。

なのでローディングの量?に合わせて%が増えていくようにしたい。

なっているように見えます。

今の時点でページのローディングが完了してから0%~100%になるプログラムが発生しているので

まあ、確かに$(function() {は「HTML読み込み終了したら」とイコールですからね。
とりあえず画像はJavaScriptでdisplay:none;するのではなくインラインstyleとかでdisplay:none;しておくのは必須として

html

1<div id="loader"> 2 Loading <span id="load-text">0%</span> 3 <div id="bar"><span></span></div> 4 </div> 5 <img src="素材/robbot.jpg" alt="" style="display:none;"/>

これだけでも一応「ローディング中感」は一応出ます。


もし「実際のページ読み込み量と連動したい」というのでしたらかなり難しい仕組みにはなります。
※ちなみに私はそこまでの仕組みを作るくらいなら画像を遅延ロードさせたりページング利用したりスケルトンスクリーン利用します。
実際に表示されるHTMLが動的に、サーバーから取得している(PHPなど)のであればAjaxと連動させればそれなりの仕組みができるかもしれませんけど。

投稿2019/02/14 06:02

m.ts10806

総合スコア80850

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

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

hiroki88

2019/02/14 13:32

ありがとうございました。 実際のページ読み込み量と連動したいというのが難しいことだと思っておりませんでした。 教えていただいたことを試してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問