2016-12-18 4 views
1

Я создаю страницу с каменной кладкой изображений, хотя эти изображения будут получены асинхронно. Кроме того, вы можете фильтровать изображения, поэтому их следует повторно отображать после каждого изменения.Vue.js и кладка - различное поведение на локальном и удаленном

Моего компонент ви:

<template> 
    <div> 
     <div class="fixed-panel"> 
      <h4 class="site-name">Smart Math Puzzles</h4> 
      <a class="btn btn-sm btn-success" @click="difficulty = 1">easy</a> 
      <a class="btn btn-sm btn-info" @click="difficulty = 2">medium</a> 
      <a class="btn btn-sm btn-warning" @click="difficulty = 3">hard</a> 
      <a class="btn btn-sm btn-primary" @click="difficulty = 0">all</a> 
     </div> 
     <div id="grid"> 
      <div class="grid-sizer"></div> 
      <div class="grid-item" v-for="puzzle in puzzles" @click="openModal(puzzle)"> 
       <img :src="puzzle.imageAddress"> 
       <div class="overlay"> 
        <span class="title">{{ puzzle.name }}</span> 
       </div> 
      </div> 
     </div> 

     <puzzle-modal></puzzle-modal> 
    </div> 
</template> 
<script> 
    import Masonry from 'masonry-layout'; 
    import ImagesLoaded from 'imagesloaded'; 
    import PuzzleModal from './PuzzleModal.vue'; 
    export default { 
     data: function() { 
      return { 
       difficulty: 0, 
       allPuzzles: [] 
      } 
     }, 

     computed: { 
      puzzles: function() { 
       return this.filterPuzzlesByDifficulty(this.difficulty); 
      } 
     }, 

     watch: { 
      puzzles: function() { 
       this.createGrid(); 
      } 
     }, 

     mounted: function() { 
      this.fetchPuzzlesData(); 
     }, 

     methods: { 
      fetchPuzzlesData: function() { 
       this.$http.get('api/puzzles') 
        .then((response) => { 
         this.allPuzzles = response.data; 
        }); 
      }, 

      openModal: function(puzzle) { 
       this.$eventHub.$emit('openModal', puzzle); 
      }, 

      filterPuzzlesByDifficulty: function(diff) { 
       if (diff === 0) 
        return this.allPuzzles; 
       else 
        return this.allPuzzles.filter((puzzle) => puzzle.difficulty === diff); 
      }, 

      imagesLoaded: function() { 
       const grid = document.querySelector('#grid'); 
       return new ImagesLoaded(grid,() => { 
        setTimeout(() => { 
         this.masonry(); 
        }, 100); 
       }); 
      }, 

      masonry: function() { 
       const grid = document.querySelector('#grid'); 
       return new Masonry(grid, { 
        percentPosition: true, 
        itemSelector: '.grid-item', 
        columnWidth: '.grid-sizer', 
       }); 
      }, 

      createGrid: function() { 
       if (!this.allPuzzles.length > 0) 
        return; 

       this.imagesLoaded(); 
      } 
     }, 

     components: { 
      'puzzle-modal': PuzzleModal, 
     } 
    } 
</script> 

Проблема заключается в том: На локальном сервере (где изображения загружаются почти мгновенно) все работает нормально, и все, я имею в виду: вы можете фильтровать изображения с использованием вычисленного значения, и они оказываются с кладкой.

Но на удаленном сервере это начинает нарушаться. Масонство не дожидаясь загрузки изображений и, кроме того, что-то очень странное для меня, вычисленное значение не работает. Если я хочу показать все, и я нажму «весь» фильтр, это прекрасно, все элементы добавляются от allPuzzles к головоломкам. Но любой другой фильтр (легкий, средний, жесткий) приводит к вычисленным головоломкам, не имеющим никаких элементов.

+0

Я решил проблему с фильтрацией. Хотя проблема с загрузкой изображений сохраняется. –

ответ

2

Хорошо. Я решил проблему оберточной this.imagesLoaded() в этом $ nextTick, поэтому метод createGrid выглядит следующим образом:.

this.$nextTick(() => this.imagesLoaded()); 

Кроме того, проблема с фильтрацией была вызвана различными типами данных. Я не знаю, почему в местном развитии это было упущено.