Я создаю страницу с каменной кладкой изображений, хотя эти изображения будут получены асинхронно. Кроме того, вы можете фильтровать изображения, поэтому их следует повторно отображать после каждого изменения.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 к головоломкам. Но любой другой фильтр (легкий, средний, жесткий) приводит к вычисленным головоломкам, не имеющим никаких элементов.
Я решил проблему с фильтрацией. Хотя проблема с загрузкой изображений сохраняется. –