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

質問編集履歴

1

コードを追加致しました。

2019/05/03 14:16

投稿

Khy
Khy

スコア118

title CHANGED
File without changes
body CHANGED
@@ -3,6 +3,88 @@
3
3
  会員制のアプリで、ユーザーごとにアバターを出来るようにしているのですが、ページを切り替えた際に画像のロードに1〜2秒ほどかかってしまいます。
4
4
  画像の表示はfirebase DatabaseのドキュメントからStorage内の画像のURLを取得して表示しております。
5
5
 
6
+ 画像を読み込んでいるページの該当箇所のコードは以下の通りです。
7
+
8
+ ```ここに言語を入力
9
+ <template>
10
+ <div class="mx-1">
11
+ <v-layout row wrap>
12
+ <!-- ユーザーカード -->
13
+ <v-flex xs6 sm6 md4 lg3 v-for="user in filteredUsers" :key="user.id">
14
+ <v-hover>
15
+ <v-card class="mx-1 mt-2" slot-scope="{ hover }" :class="`elevation-${hover ? 12 : 2}`">
16
+ <div @click="goToUserPage(user.accountName)">
17
+ <v-layout column align-center>
18
+ <v-flex class="ma-3">
19
+ <v-avatar size="80" >
20
+ <v-img :src="user.avatar" style="border: 1px #ccc solid; background-color: #eee;"/>
21
+ </v-avatar>
22
+ </v-flex>
23
+
24
+ <v-flex style="line-height: 11px;" class="mb-1">
25
+ <div class="text-truncate">{{ user.onamae }}</div>
26
+ </v-flex>
27
+ <v-flex class="mb-3" style="line-height: 11px;">
28
+ <div class="caption grey--text text-truncate">
29
+ {{user.prefecture}}
30
+ </div>
31
+ </v-flex>
32
+ </v-layout>
33
+ </div>
34
+ </v-card>
35
+ </v-hover>
36
+ </v-flex>
37
+ </v-layout>
38
+ </div>
39
+ </template>
40
+ ```
41
+
42
+ ```ここに言語を入力
43
+ <script>
44
+ import { mapGetters } from 'vuex'
45
+
46
+ export default {
47
+ computed: {
48
+ ...mapGetters([
49
+ 'filteredUsers',
50
+ ]),
51
+ },
52
+ }
53
+ </script>
54
+ ```
55
+
56
+ filteredUsersはApp.vueのcreatedで以下の通りVuexのstateに保存しております。
57
+ ```
58
+ <script>
59
+ export default{
60
+ data() {
61
+ return{
62
+ users: [],
63
+ }
64
+ },
65
+ created(){
66
+ //ユーザーを取得
67
+ db.collection('users').onSnapshot(res => {
68
+ const changes = res.docChanges()
69
+
70
+ changes.forEach(change => {
71
+ if(change.type === 'added'){
72
+ if(change.doc.id !== this.currentUserUid){
73
+ this.users.push({
74
+ ...change.doc.data(),
75
+ id: change.doc.id
76
+ });
77
+ }
78
+ this.$store.commit('setFilteredUsers', this.users);
79
+ }
80
+ })
81
+ });
82
+ }
83
+
84
+ }
85
+ </script>
86
+ ```
87
+
6
88
  Twitter Liteを使ってみたのですが、どうしてあんなに多くのユーザーの画像を早く表示できているのか分かりません。
7
89
 
8
90
  今より画像表示の速度をあげるにはどのような方法が考えられますでしょうか?