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

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

新規登録して質問してみよう
ただいま回答率
85.47%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Vuetify.js

Vuetify.jsは、マテリアルデザインを基本とするVue.jsのCSSフレームワークです。多くのマテリアルデザインのコンポーネントを提供しており、あらゆるアプリケーションに対応可能。vue-cli用テンプレートがあり、簡単にページを作成できます。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

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

HTML

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

Q&A

0回答

2706閲覧

vuetify(単一コンポーネント)でのloading画面が表示できない

momom00777

総合スコア5

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Vuetify.js

Vuetify.jsは、マテリアルデザインを基本とするVue.jsのCSSフレームワークです。多くのマテリアルデザインのコンポーネントを提供しており、あらゆるアプリケーションに対応可能。vue-cli用テンプレートがあり、簡単にページを作成できます。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

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

HTML

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

0グッド

0クリップ

投稿2020/09/15 17:52

編集2020/09/15 17:57

vuetify(単一コンポーネント)でのloading画面表示

以下のサイトのようにページに入った際にローディング画面を表示したいです。
https://littlethings.jp/blog/web/loading-animation

エラーは発生しないのですが,ローディング画面が表示できずロード中のページが見えてしまいます。

該当のソースコード

index.vue

1<template> 2<div class="container-fluid"> 3 <div id="app" v-on:load="load" > 4 <div id="loader-bf" class="is-hide"> 5 <div id="loader" class="is-hide"> 6 <img src="~/assets/img/logo.png" > 7 </div> 8 </div> 9</div> 10 11 <v-app light> 12 <br> 13 ・ 14 ・ 15 ・  16 ・ 17 </v-app> 18 </div> 19</template> 20 21<script> 22export default{ 23 methods:{ 24 load:function(){ 25 var bf=document.getElementById('loader-bf'); 26 var loader=doucument.getElementById('loader'); 27 /*ロード画面の非表示を解除*/ 28 bf.classList.remove('is-hide'); 29 loader.classList.remove('is-hide'); 30 /*読み込み完了*/ 31 window.addEventListener('load',stopload); 32 /*20秒たったら強制的にロード画面を非表示にする*/ 33 setTimeout('stopload()',20000); 34 }, 35 /*ロード画面を非表示にする*/ 36 stopload:function(){ 37 bf.classList.add('fadeout-bf'); 38 loader.classList.add('fadeout-loader'); 39 }, 40}, 41} 42</script> 43<style> 44/*ローディング画面作成*/ 45/*非表示*/ 46.is-hide{ 47 display:none; 48} 49/*ローディング画面をフェードアウト*/ 50.fadeout-bf{ 51 transition-property: opacity; 52 transition-delay: .9s; 53 transition-duration: .8s; 54 opacity:0; 55 pointer-events:none; 56} 57/*ローダーをフェードアウト*/ 58.fadeout-loader{ 59 transition-property:opacity; 60 transition-delay: .9s; 61 transition-duration: .3s; 62 opacity:0; 63 pointer-events:none; 64} 65/*ローディング画面*/ 66#loader-bf{ 67 background:#ffffff; 68 height: 100%; 69 left:0; 70 position:fixed; 71 top:0; 72 width:100%; 73 z-index:100; 74} 75#loader{ 76 heigth:120px; 77 left:50%; 78 margin-left:-60px; 79 margin-top:-60px; 80 position:fixed; 81 top:50%; 82 width:120px; 83} 84#loader img{ 85 display:inline-block; 86} 87</style> 88

ソースコードについて

3行目の「v-on:load="load"]で<script>内のmethodで作成したload関数を使い、
ロード画面を非表示にするclass"is-hide"を削除して、ロード画面を表示します。
その後読み込みが完了したもしくは強制的に20秒後にロード画面をフェードアウトさせます。

<style>に記述されている部分はフェードアウトの実際の動作を記述しています。 ### 考えられる問題 ロード中のページが見えていることから、要素を削除するclass"is-hide"が除去できていない。すなわち<script>内の関数「load」が作動していないかと思います。しかし、 「v-on:load="load"」で関数を呼び込んでいるので自分の考える動作をそれぞれの箇所で行えていれば大丈夫かと思います。 ここで問題なのが「v-on:load="load"」が作動し、関数loadが実行されるのが 「ページの内容全てをロード完了した時なのか」それとも、 「v-on:load="load"を読み出したときなのか」ということです。 後者の場合load関数が呼ばれてもページが読み込まれているため、<script>内の window.addEventListener('load',stopload); ここでstoploadが即座に実行され、ローディング画面が表示されないのではないかと思います。 v-on:「イベント」について詳細に記載されている記事や購入した教科書内では見つからず 初歩的な質問になってしまい申し訳ありませんがもしよろしければ解決法をご教授していただけないでしょうか。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

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

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

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問